遇到一个有意思的问题,不知道怎么说,大家进来看下吧
先看代码再说吧:
$catid = $_GET['id'];<br /> if( !isset( $_COOKIE[ $cookie_name ] ) ){<br /> $cart_ary = array();<br /> $cart_ary['cart'] = array();<br /> $cart_ary['item_num'] = 0;<br /> $cart_ary['total_price'] = 0.00;<br /> setcookie( $cookie_name,json_encode( $cart_ary ),time()+(7*24*60*60) );<br /> }<br /> //第一次获取不到值,所以需要抑制第一次报错<br /> $cart_ary = json_decode( str_replace( "\\","",@$_COOKIE[ $cookie_name ] ),true );<br /> if( isset( $cart_ary['cart'][ $catid ] ) ){<br /> $cart_ary['cart'][ $catid ]++ ;<br /> }else{<br /> $cart_ary['cart'][ $catid ] = 1;<br /> }<br /> $cart_ary['item_num'] = count_cart_item_num( $cart_ary['cart'] );<br /> $cart_ary['total_price'] = count_cart_total_price( $cart_ary['cart'] );<br /> setcookie( $cookie_name,json_encode( $cart_ary ),time()+(7*24*60*60) );
具体问题是这么地:
因为 $cart_ary 是个二维数组,所以当我往 cookie 里面存的时候需要先序列化一下,开始时用 serialize() 和 unserialize() 这两个函数来的,但是不知道怎么回事在 反序列化 的时候报错了“offset xxx” 这种错误,后来百度了一下说是编码问题,但是我这是在同一个页面里面啊,而且都是是UTF-8码,所以这个问题个人觉得不是,那么第一问:大家怎么能看这个问题??
然后就是后来我改用了 json_encode() 和 json_decode() 这个两个函数,但是同时有发现了一个问题就是在编码之后往 cookie 里面存的时候 cookie 的内置机制应该是对序列化的数据做了转义了,就是在双引号前面加了反斜杠“\”,所以我不得不去掉它,就像这样;
str_replace( "\\","",@$_COOKIE[ $cookie_name ] )
然后第二问就是:
我上面说 cookie 的内置机制会对将要存入的字符串做些什么东西??
好吧,有些我知道百度,但是我一直没找到好的,所以拿出来跟大家讨论下!高手莫笑~
------解决方案--------------------
你在开玩笑?
至少需要这样
$catid = $_GET['id'];
if( !isset( $_COOKIE[ $cookie_name ] ) ){
$cart_ary = array();
$cart_ary['cart'] = array();
$cart_ary['item_num'] = 0;
$cart_ary['total_price'] = 0.00;
setcookie( $cookie_name,json_encode( $cart_ary ),time()+(7*24*60*60) );
}else {
$cart_ary = json_decode( str_replace( "\\","",@$_COOKIE[ $cookie_name ] ),true );
if( isset( $cart_ary['cart'][ $catid ] ) ){
$cart_ary['cart'][ $catid ]++ ;
}else{
$cart_ary['cart'][ $catid ] = 1;
}
$cart_ary['item_num'] = count_cart_item_num( $cart_ary['cart'] );
$cart_ary['total_price'] = count_cart_total_price( $cart_ary['cart'] );
setcookie( $cookie_name,json_encode( $cart_ary ),time()+(7*24*60*60) );
}
又:count_cart_item_num 是个什么玩意?
------解决方案--------------------
1. 这个错误是因为你原先的序列化数据被破坏了,怎么被破坏的?参看第二
2. 你开启了自动转义,即魔术引号,在程序开始前,PHP已经自动帮你转义了外部提交数据,即 $_GET, $_POST, $_COOKIE 。所以你会看到莫名其妙多了个 \
你需要关掉魔术引号,修改 php.ini magic_quote_gpc=Off

PHP和Python各有优势,选择应基于项目需求。1.PHP适合web开发,语法简单,执行效率高。2.Python适用于数据科学和机器学习,语法简洁,库丰富。

PHP不是在消亡,而是在不断适应和进化。1)PHP从1994年起经历多次版本迭代,适应新技术趋势。2)目前广泛应用于电子商务、内容管理系统等领域。3)PHP8引入JIT编译器等功能,提升性能和现代化。4)使用OPcache和遵循PSR-12标准可优化性能和代码质量。

PHP的未来将通过适应新技术趋势和引入创新特性来实现:1)适应云计算、容器化和微服务架构,支持Docker和Kubernetes;2)引入JIT编译器和枚举类型,提升性能和数据处理效率;3)持续优化性能和推广最佳实践。

在PHP中,trait适用于需要方法复用但不适合使用继承的情况。1)trait允许在类中复用方法,避免多重继承复杂性。2)使用trait时需注意方法冲突,可通过insteadof和as关键字解决。3)应避免过度使用trait,保持其单一职责,以优化性能和提高代码可维护性。

依赖注入容器(DIC)是一种管理和提供对象依赖关系的工具,用于PHP项目中。DIC的主要好处包括:1.解耦,使组件独立,代码易维护和测试;2.灵活性,易替换或修改依赖关系;3.可测试性,方便注入mock对象进行单元测试。

SplFixedArray在PHP中是一种固定大小的数组,适用于需要高性能和低内存使用量的场景。1)它在创建时需指定大小,避免动态调整带来的开销。2)基于C语言数组,直接操作内存,访问速度快。3)适合大规模数据处理和内存敏感环境,但需谨慎使用,因其大小固定。

PHP通过$\_FILES变量处理文件上传,确保安全性的方法包括:1.检查上传错误,2.验证文件类型和大小,3.防止文件覆盖,4.移动文件到永久存储位置。

JavaScript中处理空值可以使用NullCoalescingOperator(??)和NullCoalescingAssignmentOperator(??=)。1.??返回第一个非null或非undefined的操作数。2.??=将变量赋值为右操作数的值,但前提是该变量为null或undefined。这些操作符简化了代码逻辑,提高了可读性和性能。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

禅工作室 13.0.1
功能强大的PHP集成开发环境

Atom编辑器mac版下载
最流行的的开源编辑器

Dreamweaver CS6
视觉化网页开发工具

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能