dongtan3395 2018-08-01 21:20
浏览 73


I am getting an error while building my go code on an Ubuntu machine. I have check GOPATH variables and everything seems fine. Below is stack trace of error I am getting:

/go/src/Chaincodeexample$ go build # _/home/ubuntu/go/src/Chaincodeexample

./Samplesupplychain.go:13:14: cannot refer to unexported name shim.logger
./Samplesupplychain.go:91:5: syntax error: non-declaration statement outside function body

Below is my code :





var logger = shim.logger("my logger")
//Create a struct for these 2 values
type testuser struct{
    Username string `json:"username"`
    Fileuploaded string `json:"fileuploaded"`

//A function to create a user on the ledger

func CreateUser(stub shim.ChaincodeStubInterface, args []string) ([]byte, error){
    if len(args) < 2 {
        logger.Error("Invalid number of args")
        return nil, errors.New("Expected atleast 1 argument for user creation")

    var Username = args[0]
    var UsernameInput = args[1]
    //trying to understand
    err := stub.PutState(Username, []byte(UsernameInput))
    if err != nil {
        logger.Error("Could not save new User to ledger", err)
        return nil, err

    var customEvent = "{eventType: 'UserCreation', description:" + Username + "' Successfully created'}"
    err = stub.SetEvent("evtSender", []byte(customEvent))
    if err != nil {
        return nil, err
    logger.Info("Successfully saved a supply chain user")
    return nil, nil


func Checkuploadstatus(stub shim.ChaincodeStubInterface, args []string) ([]byte, error) {
    logger.Debug("Entering supply-chain application")

    if len(args) < 1 {
        logger.Error("Invalid number of arguments")
        return nil, errors.New("Missing details")

    var Fileuploadedstatus = args[0] 

    bytes, err := stub.GetState(Fileuploadedstatus) 
    if err != nil {
        logger.Error("Could not fetch Fileuploadedstatus with "+ Fileuploadedstatus +" from ledger", err)
        return nil, err
    return bytes, nil

func (t *testuser) Init(stub shim.ChaincodeStubInterface, function string, args []string) ([]byte, error) {
    return nil, nil


func (t *testuser) Query(stub shim.ChaincodeStubInterface, function string, args []string) ([]byte, error) {
    if function == "Checkuploadstatus" {
        return Checkuploadstatus(stub, args)
    return nil, nil

func (t *testuser) Invoke(stub shim.ChaincodeStubInterface, function string, args []string) ([]byte, error) {
    if function == "CreateUser" {
        return CreateUser(stub, args)
        } else {
            return nil, errors.New(username + " does not have access to create a User")

    return nil, nil

Give me idea to resolve this.

  • 写回答

1条回答 默认 最新

  • donglu8334 2018-08-02 09:29

    In Go only you can only access names in other packages if they start with an upper-case letter. This is kind of like using public and private in Java or C++.

    Call your type Logger instead of logger and it will work.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?



  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
  • ¥15 错误 LNK2001 无法解析的外部符号
  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能
  • ¥15 jmeter脚本回放有的是对的有的是错的
  • ¥15 r语言蛋白组学相关问题
  • ¥15 Python时间序列如何拟合疏系数模型