admin 管理员组文章数量: 887018
php 插入二进制,PHP
我必须使用php的mysql改进库将一行插入到mysql中具有类型为VARBINARY的主键的表中.
该字段的内容是计算的sha1哈希.
如果我以旧的方式运行查询它完美地工作:
$mysqli->$query("INSERT INTO table (id, field1) VALUES (0x" . $id . ",'" . $field1 . "')");
但是当我尝试将其作为准备好的声明执行时,我无法弄清楚如何做到这一点.如果
我执行等效的操作:
if($stmt = $mysqli->prepare("INSERT INTO table (id, field1) VALUES (?, ?)")) {
$stmt->bind_param('ss', "0x".$id, $field1);
//execute statement
}
它会抛出一个异常,说明这个字段的内容太大了.如果我尝试将其作为BLOB字段插入:
if($stmt = $mysqli->prepare("INSERT INTO table (id, field1) VALUES (?, ?)")) {
$stmt->bind_param('bs', $id, $field1);
//execute statement
}
它没有给出错误,插入了行,但标识符字段现在为空(不为空,为空).
我知道我可以混合查询并输入字符串中连接的id和其他字段作为预准备语句的绑定参数,但我只是想知道插入这个的正确方法是什么,也许它会帮助某些人未来.
解决方法:
PHP的sha1函数返回十六进制数字的字符串表示形式.
这意味着如果你将它打印到屏幕上,它将显示一个十六进制数字.但在内存中,它是一堆ASCII字符.
所以,取十六进制数1A2F.作为内存中的ASCII,将是0x31413246,而不是0x1A2F
MySQL的普通接口将所有参数作为字符串发送.使用普通接口时,MySQL会将ASCII字符串转换为二进制值.
新的预处理语句方法将所有内容都以二进制形因此,“1A2F”的漂亮值现在将作为0x31413246发送并插入到列中. – source: dev.mysql – Prepared statements
相反,通过使用以下方法将Hex字符串打包成二进制字符串来转换它:
$binId = pack("H*", $id); // this string is not ASCII, don't print it to the screen! That will be ugly.
然后将$binId传递给MySQLi预处理语句而不是$id.
标签:php,mysql,prepared-statement
来源: .html
版权声明:本文标题:php 插入二进制,PHP 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.freenas.com.cn/jishu/1731195659h1464413.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论