我有以下字符串由客户端发送到服务器:
3%D3%E1f%7C%AF%B0a%B58%81%92%F9M%90%0CD%A0Y%9C // string in the actual URL
3Óáf|¯°aµ8’ùMD Yœ // var_dump($_GET)
原始字符串应为:
33D3E1667CAFB061B5388192F94D900C44A0599C
我的问题是,我不知道如何对其进行编码/解码,这样我就可以进行数据库搜索,因为排序规则类型不匹配。我试过urlencode
/urldecode
、mb_string_convert
、utf8_encode
、iconv
,但没有成功。有什么想法吗?
Laravel在尝试使用字符串进行搜索时抛出以下异常:
'SQLSTATE[HY000]: General error: 1267 Illegal mix of collations (latin1_swedish_ci,IMPLICIT) and (utf8_general_ci,COERCIBLE)...
我无法控制客户端的编码是什么。奇怪的值是使用Laravel's Log::imfo()
将其记录到日志文件中
是否尝试发送post请求而不是get请求,并将字符串作为实际字符串发送。
或者可以将数据库编码更改为UTF-8(它可以很好地处理瑞典语,无需选择拉丁-瑞典语版本)。
解决方案是通过bin2hex()
函数调用检索参数。