Size: a a a

2020 December 13

АИ

Арман Исмаилов... in Go-go!
Zver
Ну вы его вывели следом.
Данные выходят из return
источник

АИ

Арман Исмаилов... in Go-go!
Не просто в консоли
источник

АИ

Арман Исмаилов... in Go-go!
Go Go
Какую библиотеку ?
C библиотека для работы с ЭЦП
источник

GG

Go Go in Go-go!
Арман Исмаилов
C библиотека для работы с ЭЦП
Хз что это
источник

AB

Andrey Burov in Go-go!
Арман Исмаилов
Ребята, я не знаю как это объяснить, но есть функция подписи данных использующая so библиотеку:
func SignData(data string, flags int) (string, error) {
 var result C.uchar
 cdata := C.CString(data)
 cflags := C.int(flags)
 log.Println("before sign")
 if C.sign_data(cflags, cdata, &result) != 0 {
   return "", GetLastErrorString()
 }
 data2 := (*C.char)(unsafe.Pointer(&result))
 C.free(unsafe.Pointer(cdata))
 log.Println("after sign")
 return C.GoString(data2), GetLastErrorString()
}
На входе задаем данные для подписи, а на выходе получаем данные вперемешку с выводом log.Println:
MIISeAYJKoZIhvcNAQcCoIISaTCCEmUCAQExDTALBglghkgBZQMEAgEwRQYJKoZIafter sign
Как туда попало after sign?
C.sign_data(cflags, cdata, &result) != 0 у тебя это == 0
источник

Z

Zver in Go-go!
А без ансейф.
источник

AB

Andrey Burov in Go-go!
Арман Исмаилов
Ребята, я не знаю как это объяснить, но есть функция подписи данных использующая so библиотеку:
func SignData(data string, flags int) (string, error) {
 var result C.uchar
 cdata := C.CString(data)
 cflags := C.int(flags)
 log.Println("before sign")
 if C.sign_data(cflags, cdata, &result) != 0 {
   return "", GetLastErrorString()
 }
 data2 := (*C.char)(unsafe.Pointer(&result))
 C.free(unsafe.Pointer(cdata))
 log.Println("after sign")
 return C.GoString(data2), GetLastErrorString()
}
На входе задаем данные для подписи, а на выходе получаем данные вперемешку с выводом log.Println:
MIISeAYJKoZIhvcNAQcCoIISaTCCEmUCAQExDTALBglghkgBZQMEAgEwRQYJKoZIafter sign
Как туда попало after sign?
добавь внутрь if, перед return еще один log и все станет ясно
источник

АИ

Арман Исмаилов... in Go-go!
Andrey Burov
C.sign_data(cflags, cdata, &result) != 0 у тебя это == 0
Но даже если так, должна возвратиться пустая строка и ошибка
источник

Z

Zver in Go-go!
Посмотри, что в result перед этими танцами с unsafe.
источник

AB

Andrey Burov in Go-go!
Арман Исмаилов
Но даже если так, должна возвратиться пустая строка и ошибка
считай кол-во строк с кол-вом log.Print
источник

Z

Zver in Go-go!
И если здесь log.Println("after sign”) поменять текст, то в выводе тоже изменится?
источник

АИ

Арман Исмаилов... in Go-go!
Andrey Burov
считай кол-во строк с кол-вом log.Print
Все правильно, у меня 2 раза after sign в выводе из функции и в log.Println 😮
источник

АИ

Арман Исмаилов... in Go-go!
Zver
И если здесь log.Println("after sign”) поменять текст, то в выводе тоже изменится?
Да
источник

Z

Zver in Go-go!
Значит с usafe захватывается кусок памяти с "after sign”.
источник

Z

Zver in Go-go!
Вообще как C.GoString(data2) узнает длину куска памяти передаваемую через unsafe.Pointer?
источник

Z

Zver in Go-go!
Может не так данные передаете?
источник

Z

Zver in Go-go!
Или поинтер не так получаете.
источник

АИ

Арман Исмаилов... in Go-go!
Zver
Посмотри, что в result перед этими танцами с unsafe.
В result половина подписи без after sign😶
источник

AB

Andrey Burov in Go-go!
Арман Исмаилов
Все правильно, у меня 2 раза after sign в выводе из функции и в log.Println 😮
go clean -cache -modcache -i -r
источник

Z

Zver in Go-go!
По мне что-то не так с манипуляциями с unsafe.Pointer. Поэтому лишние данные захватываются.
источник