1

设想:

  • 我有一个签名板,它的点(列表)保存到 SQL 服务器。
  • 我从数据库中获取它并将其显示到另一个屏幕上。

Flutter 保存代码

我只会提供我认为相关的重要代码。

// This is save button
onPressed() {
   data = {
     'Signature' : _fbKey.currentState.value['signature'].toString()
   }
}

// trigger _save function
if (_fbKey.currentState.saveAndValidate()) {
  _save(data);
}

// _save function
_save(data) async {
   final response = await http.post('url here..', body: data);
}

Laravel 代码 我将提供我也认为相关的代码

Route::middleware('admin')->post('link...', function (Request $request) {
   $user = new User;

   $user->Signature= $request->Signature;

   $user->save();

   return response()->json([
        'message' => 'Success',
        'data' => $user
    ], 200);
});

Flutter 获取代码

getData() async {
   final response = await http.get('url goes here');

   var signRes = jsonDecode(response.body);
   String rawSign = signRes['data']['Signature'];
   print(rawSign); // output [137, ....so on]

   List<int> list = rawSign.codeUnits;
   print(list); // the output that I expected suddenly change to [91, ..... so on]

   Uint8List signature = Uint8List.fromList(list); 

}

@override
Widget build(BuildContext context) {
   return Scaffold(
   .......
   .......
      child: Container(
         child: Image.memory(signature);         
      )
   )
}

SQL 服务器

column : Signature
datatype: nvarchar(max)

我得到的例外:

无法实例化图像编解码器

问题

  • 如您所见,我从签名板获得的点(列表)是合法的点(列表),但我toString()在保存时将其转换为,因为Flutter抛出异常说 can cast Uint8Arrat to String。那么,是否可以从数据库中获取字符串列表点而不将其转换为.codeUnits?因为这样做时,value changes from what expected.
4

1 回答 1

0

多亏了另一个 SO 问题,我终于让它工作了。

基本上,我先将数据转换为base64,然后再保存到数据库中。

data = {
  'Signature' : base64Encode(_fbKey.currentState.value['signature'])
}

然后将其转换回其原始形式

var signRes = jsonDecode(response.body);
String rawSign = signRes['data']['Signature'];
Uint8List signature = base64Decode(rawSign);

最后,繁荣。图像按预期成功呈现在应用程序中。

于 2020-03-30T15:47:01.370 回答