热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

php把数组保存数据库程序代码

我们在做缓存文件时经常会要把php代码或数组转换成字符串保存到数据库中,下面我来介绍两种把数组保存到数据库的方法。方法一:用serialize

我们在做缓存文件时经常会要把php代码或数组转换成字符串保存到数据库中,下面我来介绍两种把数组保存到数据库的方法。

方法一:用serialize写入,再用unserialize输出

serialize()就是将PHP中的变量如对象(object),数组(array)等等的值序列化为字符串后存储起来.序列化的字符串我们可以 存储在其他地方如数据库、Session、COOKIE等,序列化的操作并不会丢失这些值的类型和结构。这样这些变量的数据就可以在PHP页面、甚至是不 同PHP程序间传递了。

而unserialize()就是把序列化的字符串转换回PHP的值。返回的是转换之后的值,可为 integer、float、string、array 或 object如果传递的字符串不可解序列化,则返回 FALSE,代码如下:

  1. class db { 
  2.  private $host
  3.  private $user
  4.  private $pwd
  5.  private $dbname
  6.  private $Mysqli
  7.  function __construct($host$user$pwd$dbname) { 
  8.   $this->host = $host
  9.   $this->user = $user
  10.   $this->pwd = $pwd
  11.   $this->dbname = $dbname
  12.   $this->db(); 
  13.  } 
  14.  function db() { 
  15.   $this->mysqli = new mysqli ( $this->host, $this->user, $this->pwd, $this->dbname ); 
  16.  } 
  17.  function select() { 
  18.   $this->mysqli->query("SET CHARSET GBK"); 
  19.   $sql = "SELECT id,cname FROM hdw_channel"
  20.   $result = $this->mysqli 
  21.    ->query ( $sql ); 
  22.   $rows = array (); 
  23.   while ( $row = $result->fetch_assoc () ) { 
  24.    $rows [] = $row
  25.   } 
  26.   ECHO "
    "
  27.   print_r ( $rows ); 
  28.  } 
  29.  function __wakeup(){   //反序列化, 
  30.   $this->db(); 
  31.  } 
  32. $chanel = new db("localhost",'root','','hdcms'); 
  33. //$chanel->select(); 
  34. session_start(); 
  35. $_SESSION['channel_obj'] = serialize($chanel);   //将对象序列化,保存的是对象的属性,没有方法,所以要用__wakeup() 
  36.  
  37. class ren{ 
  38.  private $name
  39.  private $age
  40.  function __construct($name,$age){ 
  41.   $this->name =$name
  42.   $this->age = $age
  43.  } 
  44.  function show(){ 
  45.   echo "姓名是:{$this->name}  年龄是:{$this->age}"
  46.  } 
  47.  function __sleep(){ 
  48.   return array_keys(get_object_vars($this));  //或得数组里边的键名,序列化某些变量 
  49.  } 
  50. $zao = new ren("赵六",44); 
  51. echo serialize($zao);       //序列化(指定哪个变量序列化) 
  52. ==================================== 
  53. session_start(); 
  54. include '59.php'
  55. $channel_obj=unserialize($_SESSION['channel_obj']);  //反序列化类对象 
  56. $channel_obj->select();  //有了__wakeup方法才可以起作用 

方法二:用json_encode写入,再用json_decode输出

json_encode之前,把所有数组内所有内容都用urlencode()处理一下,然用json_encode()转换成json字符串,最后再用urldecode()将编码过的中文转回来,代码如下:

  1. /************************************************************** 
  2.  * 
  3.  * 使用特定function对数组中所有元素做处理 
  4.  * @param string &$array  要处理的字符串 
  5.  * @param string $function 要执行的函数 
  6.  * @return boolean $apply_to_keys_also  是否也应用到key上 
  7.  * @access public 
  8.  * 
  9.  *************************************************************/ 
  10. function arrayRecursive(&$array$function$apply_to_keys_also = false) 
  11.     static $recursive_counter = 0; 
  12.     if (++$recursive_counter > 1000) { 
  13.         die('possible deep recursion attack'); 
  14.     } 
  15.     foreach ($array as $key => $value) { 
  16.         if (is_array($value)) { 
  17.             arrayRecursive($array[$key], $function$apply_to_keys_also); 
  18.         } else { 
  19.             $array[$key] = $function($value); 
  20.         } 
  21.  
  22.         if ($apply_to_keys_also && is_string($key)) { 
  23.             $new_key = $function($key); 
  24.             if ($new_key != $key) { 
  25.                 $array[$new_key] = $array[$key]; 
  26.                 unset($array[$key]); 
  27.             } 
  28.         } 
  29.     } 
  30.     $recursive_counter--; 
  31.  
  32. /************************************************************** 
  33.  * 
  34.  * 将数组转换为JSON字符串(兼容中文) 
  35.  * @param array $array  要转换的数组 
  36.  * @return string  转换得到的json字符串 
  37.  * @access public 
  38.  * 
  39.  *************************************************************/ 
  40. function JSON($array) { 
  41.  arrayRecursive($array'urlencode', true); 
  42.  $json = json_encode($array); 
  43.  return urldecode($json); 
  44. $array = array 
  45.        ( 
  46.           'Name'=>'希亚'
  47.           'Age'=>20 
  48.        ); 
  49.  
  50. echo JSON($array); 
  51. ?>

推荐阅读
  • MongoDB的核心特性与架构解析
    本文深入探讨了MongoDB的核心特性,包括其强大的查询语言、灵活的文档模型以及高效的索引机制。此外,还详细介绍了MongoDB的体系结构,解释了其文档、集合和数据库的层次关系,并对比了MongoDB与传统关系型数据库(如MySQL)的逻辑结构。 ... [详细]
  • 本文深入探讨了MySQL中常见的面试问题,包括事务隔离级别、存储引擎选择、索引结构及优化等关键知识点。通过详细解析,帮助读者在面对BAT等大厂面试时更加从容。 ... [详细]
  • 1.介绍有时候我们需要一些模拟数据来进行测试,今天简单记录下如何用存储过程生成一些随机数据。2.建表我们新建一张学生表和教师表如下:CREATETABLEstudent(idINT ... [详细]
  • 本文详细介绍了在 Windows 7 系统中配置 Nginx 1.10.3 和 PHP 7.1.1 NTS 的步骤,包括修改 PHP 配置文件、处理依赖项以及创建批处理脚本启动和停止服务。重点解释了如何解决常见的运行时错误。 ... [详细]
  • 深入理解ExtJS:从入门到精通
    本文详细介绍了ExtJS的功能及其在大型企业前端开发中的应用。通过实例和详细的文件结构解析,帮助初学者快速掌握ExtJS的核心概念,并提供实用技巧和最佳实践。 ... [详细]
  • 通常情况下,修改my.cnf配置文件后需要重启MySQL服务才能使新参数生效。然而,通过特定命令可以在不重启服务的情况下实现配置的即时更新。本文将详细介绍如何在线调整MySQL配置,并验证其有效性。 ... [详细]
  • 本文详细介绍了MySQL数据库中的Bin Log和Redo Log,阐述了它们在日志记录机制、应用场景以及数据恢复方面的区别。通过对比分析,帮助读者更好地理解这两种日志文件的作用和特性。 ... [详细]
  • 本文详细介绍了 phpMyAdmin 的安装与配置方法,适用于多个版本的 phpMyAdmin。通过本教程,您将掌握从下载到部署的完整流程,并了解如何根据不同的环境进行必要的配置调整。 ... [详细]
  • 优化Flask应用的并发处理:解决Mysql连接过多问题
    本文探讨了在Flask应用中通过优化后端架构来应对高并发请求,特别是针对Mysql 'too many connections' 错误的解决方案。我们将介绍如何利用Redis缓存、Gunicorn多进程和Celery异步任务队列来提升系统的性能和稳定性。 ... [详细]
  • 使用JS、HTML5和C3创建自定义弹出窗口
    本文介绍如何结合JavaScript、HTML5和C3.js来实现一个功能丰富的自定义弹出窗口。通过具体的代码示例,详细讲解了实现过程中的关键步骤和技术要点。 ... [详细]
  • 本文详细介绍了如何解决 Microsoft SQL Server 中用户 'sa' 登录失败的问题。错误代码为 18470,提示该帐户已被禁用。我们将通过 Windows 身份验证方式登录,并启用 'sa' 帐户以恢复其访问权限。 ... [详细]
  • 配置PHPStudy环境并使用DVWA进行Web安全测试
    本文详细介绍了如何在PHPStudy环境下配置DVWA( Damn Vulnerable Web Application ),并利用该平台进行SQL注入和XSS攻击的练习。通过此过程,读者可以熟悉常见的Web漏洞及其利用方法。 ... [详细]
  • 本文详细介绍如何使用 Apache Spark 执行基本任务,包括启动 Spark Shell、运行示例程序以及编写简单的 WordCount 程序。同时提供了参数配置的注意事项和优化建议。 ... [详细]
  • 在尝试从数据库获取设置的过程中,遇到了一个致命错误:Fatal error: Call to a member function bind_param() on boolean。本文将详细分析该错误的原因,并提供解决方案。 ... [详细]
  • docker镜像重启_docker怎么启动镜像dock ... [详细]
author-avatar
mobiledu2502883647
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有