加入收藏 | 设为首页 | 会员中心 | 我要投稿 岳阳站长网 (https://www.0730zz.com.cn/)- 科技、建站、数据库平台、数据湖、视觉智能!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

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

发布时间:2022-07-24 10:09:24 所属栏目:PHP教程 来源:互联网
导读:我们在做缓存文件时经常会要把php代码或数组转换成字符串保存到数据库中,下面我来介绍两种把数组保存到数据库的方法。 方法一:用serialize写入,再用unserialize输出 serialize()就是将PHP中的变量如对象(object),数组(array)等等的值序列化为字符串后存储起
  我们在做缓存文件时经常会要把php代码或数组转换成字符串保存到数据库中,下面我来介绍两种把数组保存到数据库的方法。
 
  方法一:用serialize写入,再用unserialize输出
 
  serialize()就是将PHP中的变量如对象(object),数组(array)等等的值序列化为字符串后存储起来.序列化的字符串我们可以 存储在其他地方如数据库、Session、Cookie等,序列化的操作并不会丢失这些值的类型和结构。这样这些变量的数据就可以在PHP页面、甚至是不 同PHP程序间传递了。
 
  而unserialize()就是把序列化的字符串转换回PHP的值。返回的是转换之后的值,可为 integer、float、string、array 或 object如果传递的字符串不可解序列化,则返回 FALSE,代码如下:
 
  class db {
   private $host;
   private $user;
   private $pwd;
   private $dbname;
   private $Mysqli;
   function __construct($host, $user, $pwd, $dbname) {
    $this->host = $host;
    $this->user = $user;
    $this->pwd = $pwd;
    $this->dbname = $dbname;
    $this->db();
   }
   function db() {
    $this->mysqli = new mysqli ( $this->host, $this->user, $this->pwd, $this->dbname );
   }
   function select() {
    $this->mysqli->query("SET CHARSET GBK");
    $sql = "SELECT id,cname FROM hdw_channel";
    $result = $this->mysqli
     ->query ( $sql );
    $rows = array ();
    while ( $row = $result->fetch_assoc () ) {
     $rows [] = $row;
    }
    ECHO "<PRE>";
    print_r ( $rows );
   }
   function __wakeup(){   //反序列化,
    $this->db();
   }
  }
  $chanel = new db("localhost",'root','','hdcms');
  //$chanel->select();
  session_start();
  $_SESSION['channel_obj'] = serialize($chanel);   //将对象序列化,保存的是对象的属性,没有方法,所以要用__wakeup()
   
  class ren{
   private $name;
   private $age;
   function __construct($name,$age){
    $this->name =$name;
    $this->age = $age;
   }
   function show(){
    echo "姓名是:{$this->name}  年龄是:{$this->age}";
   }
   function __sleep(){
    return array_keys(get_object_vars($this));  //或得数组里边的键名,序列化某些变量
   }
  }
  $zao = new ren("赵六",44);
  echo serialize($zao);       //序列化(指定哪个变量序列化)
  ====================================
  session_start();
  include '59.php';
  $channel_obj=unserialize($_SESSION['channel_obj']);  //反序列化类对象
  $channel_obj->select();  //有了__wakeup方法才可以起作用
  方法二:用json_encode写入,再用json_decode输出
 
  json_encode之前,把所有数组内所有内容都用urlencode()处理一下,然用json_encode()转换成json字符串,最后再用urldecode()将编码过的中文转回来,代码如下:
 
  <?php
  /**************************************************************
   *
   * 使用特定function对数组中所有元素做处理
   * @param string &$array  要处理的字符串
   * @param string $function 要执行的函数
   * @return boolean $apply_to_keys_also  是否也应用到key上
   * @access public
   *
   *************************************************************/
  function arrayRecursive(&$array, $function, $apply_to_keys_also = false)
  {
      static $recursive_counter = 0;
      if (++$recursive_counter > 1000) {
          die('possible deep recursion attack');
      }
      foreach ($array as $key => $value) {
          if (is_array($value)) {
              arrayRecursive($array[$key], $function, $apply_to_keys_also);
          } else {
              $array[$key] = $function($value);
          }
   
          if ($apply_to_keys_also && is_string($key)) {
              $new_key = $function($key);
              if ($new_key != $key) {
                  $array[$new_key] = $array[$key];
                  unset($array[$key]);
              }
          }
      }
      $recursive_counter--;
  }
   
  /**************************************************************
   *
   * 将数组转换为JSON字符串(兼容中文)
   * @param array $array  要转换的数组
   * @return string  转换得到的json字符串
   * @access public
   *
   *************************************************************/
  function JSON($array) {
   arrayRecursive($array, 'urlencode', true);
   $json = json_encode($array);
   return urldecode($json);
  }
  $array = array
         (
            'Name'=>'希亚',
            'Age'=>20
         );
   
  echo JSON($array);
  ?>

(编辑:岳阳站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读