侯体宗的博客
  • 首页
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

PHP实现的json类实例

php  /  管理员 发布于 7年前   152

本文实例讲述了PHP实现的json类。分享给大家供大家参考。具体如下:

这里注意json_encode只有(PHP 5 >= 5.2.0, PECL json >= 1.2.0)才有

* @author  Matt Knapp * @author  Brett Stimmerman * @copyright 2005 Michal Migurski* @version  CVS: $Id: JSON.php,v 1.31 2006/06/28 05:54:17 migurski Exp $* @license  http://www.opensource.org/licenses/bsd-license.php* @link  http://pear.php.net/pepr/pepr-proposal-show.php?id=198*//*** Marker constant for Services_JSON::decode(), used to flag stack state*/define('SERVICES_JSON_SLICE', 1);/*** Marker constant for Services_JSON::decode(), used to flag stack state*/define('SERVICES_JSON_IN_STR', 2);/*** Marker constant for Services_JSON::decode(), used to flag stack state*/define('SERVICES_JSON_IN_ARR', 3);/*** Marker constant for Services_JSON::decode(), used to flag stack state*/define('SERVICES_JSON_IN_OBJ', 4);/*** Marker constant for Services_JSON::decode(), used to flag stack state*/define('SERVICES_JSON_IN_CMT', 5);/*** Behavior switch for Services_JSON::decode()*/define('SERVICES_JSON_LOOSE_TYPE', 16);/*** Behavior switch for Services_JSON::decode()*/define('SERVICES_JSON_SUPPRESS_ERRORS', 32);/*** Converts to and from JSON format.** Brief example of use:** * // create a new instance of Services_JSON* $json = new Services_JSON();** // convert a complexe value to JSON notation, and send it to the browser* $value = array('foo', 'bar', array(1, 2, 'baz'), array(3, array(4)));* $output = $json->encode($value);** print($output);* // prints: ["foo","bar",[1,2,"baz"],[3,[4]]]** // accept incoming POST data, assumed to be in JSON notation* $input = file_get_contents('php://input', 1000000);* $value = $json->decode($input);* */class Services_JSON{ /** * constructs a new JSON instance * * @param int  $use object behavior flags; combine with boolean-OR * *       possible values: *       - SERVICES_JSON_LOOSE_TYPE: loose typing. *         "{...}" syntax creates associative arrays *         instead of objects in decode(). *       - SERVICES_JSON_SUPPRESS_ERRORS: error suppression. *         Values which can't be encoded (e.g. resources) *         appear as NULL instead of throwing errors. *         By default, a deeply-nested resource will *         bubble up with an error, so all return values *         from encode() should be checked with isError() */ function Services_JSON($use = 0) {  $this->use = $use; } /** * convert a string from one UTF-16 char to one UTF-8 char * * Normally should be handled by mb_convert_encoding, but * provides a slower PHP-only method for installations * that lack the multibye string extension. * * @param string $utf16 UTF-16 character * @return string UTF-8 character * @access private */ function utf162utf8($utf16) {  // oh please oh please oh please oh please oh please  if(function_exists('mb_convert_encoding')) {   return mb_convert_encoding($utf16, 'UTF-8', 'UTF-16');  }  $bytes = (ord($utf16{0}) << 8) | ord($utf16{1});  switch(true) {   case ((0x7F & $bytes) == $bytes):    // this case should never be reached, because we are in ASCII range    // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8    return chr(0x7F & $bytes);   case (0x07FF & $bytes) == $bytes:    // return a 2-byte UTF-8 character    // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8    return chr(0xC0 | (($bytes >> 6) & 0x1F))      . chr(0x80 | ($bytes & 0x3F));   case (0xFFFF & $bytes) == $bytes:    // return a 3-byte UTF-8 character    // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8    return chr(0xE0 | (($bytes >> 12) & 0x0F))      . chr(0x80 | (($bytes >> 6) & 0x3F))      . chr(0x80 | ($bytes & 0x3F));  }  // ignoring UTF-32 for now, sorry  return ''; } /** * convert a string from one UTF-8 char to one UTF-16 char * * Normally should be handled by mb_convert_encoding, but * provides a slower PHP-only method for installations * that lack the multibye string extension. * * @param string $utf8 UTF-8 character * @return string UTF-16 character * @access private */ function utf82utf16($utf8) {  // oh please oh please oh please oh please oh please  if(function_exists('mb_convert_encoding')) {   return mb_convert_encoding($utf8, 'UTF-16', 'UTF-8');  }  switch(strlen($utf8)) {   case 1:    // this case should never be reached, because we are in ASCII range    // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8    return $utf8;   case 2:    // return a UTF-16 character from a 2-byte UTF-8 char    // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8    return chr(0x07 & (ord($utf8{0}) >> 2))      . chr((0xC0 & (ord($utf8{0}) << 6))       | (0x3F & ord($utf8{1})));   case 3:    // return a UTF-16 character from a 3-byte UTF-8 char    // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8    return chr((0xF0 & (ord($utf8{0}) << 4))       | (0x0F & (ord($utf8{1}) >> 2)))      . chr((0xC0 & (ord($utf8{1}) << 6))       | (0x7F & ord($utf8{2})));  }  // ignoring UTF-32 for now, sorry  return ''; } /** * encodes an arbitrary variable into JSON format * * @param mixed $var any number, boolean, string, array, or object to be encoded. *       see argument 1 to Services_JSON() above for array-parsing behavior. *       if var is a strng, note that encode() always expects it *       to be in ASCII or UTF-8 format! * * @return mixed JSON string representation of input var or an error if a problem occurs * @access public */ function encode($var) {  switch (gettype($var)) {   case 'boolean':    return $var ? 'true' : 'false';   case 'NULL':    return 'null';   case 'integer':    return (int) $var;   case 'double':   case 'float':    return (float) $var;   case 'string':    // STRINGS ARE EXPECTED TO BE IN ASCII OR UTF-8 FORMAT    $ascii = '';    $strlen_var = strlen($var);    /*    * Iterate over every character in the string,    * escaping with a slash or encoding to UTF-8 where necessary    */    for ($c = 0; $c < $strlen_var; ++$c) {     $ord_var_c = ord($var{$c});     switch (true) {      case $ord_var_c == 0x08:       $ascii .= '\b';       break;      case $ord_var_c == 0x09:       $ascii .= '\t';       break;      case $ord_var_c == 0x0A:       $ascii .= '\n';       break;      case $ord_var_c == 0x0C:       $ascii .= '\f';       break;      case $ord_var_c == 0x0D:       $ascii .= '\r';       break;      case $ord_var_c == 0x22:      case $ord_var_c == 0x2F:      case $ord_var_c == 0x5C:       // double quote, slash, slosh       $ascii .= '\\'.$var{$c};       break;      case (($ord_var_c >= 0x20) && ($ord_var_c <= 0x7F)):       // characters U-00000000 - U-0000007F (same as ASCII)       $ascii .= $var{$c};       break;      case (($ord_var_c & 0xE0) == 0xC0):       // characters U-00000080 - U-000007FF, mask 110XXXXX       // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8       $char = pack('C*', $ord_var_c, ord($var{$c + 1}));       $c += 1;       $utf16 = $this->utf82utf16($char);       $ascii .= sprintf('\u%04s', bin2hex($utf16));       break;      case (($ord_var_c & 0xF0) == 0xE0):       // characters U-00000800 - U-0000FFFF, mask 1110XXXX       // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8       $char = pack('C*', $ord_var_c,           ord($var{$c + 1}),           ord($var{$c + 2}));       $c += 2;       $utf16 = $this->utf82utf16($char);       $ascii .= sprintf('\u%04s', bin2hex($utf16));       break;      case (($ord_var_c & 0xF8) == 0xF0):       // characters U-00010000 - U-001FFFFF, mask 11110XXX       // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8       $char = pack('C*', $ord_var_c,           ord($var{$c + 1}),           ord($var{$c + 2}),           ord($var{$c + 3}));       $c += 3;       $utf16 = $this->utf82utf16($char);       $ascii .= sprintf('\u%04s', bin2hex($utf16));       break;      case (($ord_var_c & 0xFC) == 0xF8):       // characters U-00200000 - U-03FFFFFF, mask 111110XX       // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8       $char = pack('C*', $ord_var_c,           ord($var{$c + 1}),           ord($var{$c + 2}),           ord($var{$c + 3}),           ord($var{$c + 4}));       $c += 4;       $utf16 = $this->utf82utf16($char);       $ascii .= sprintf('\u%04s', bin2hex($utf16));       break;      case (($ord_var_c & 0xFE) == 0xFC):       // characters U-04000000 - U-7FFFFFFF, mask 1111110X       // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8       $char = pack('C*', $ord_var_c,           ord($var{$c + 1}),           ord($var{$c + 2}),           ord($var{$c + 3}),           ord($var{$c + 4}),           ord($var{$c + 5}));       $c += 5;       $utf16 = $this->utf82utf16($char);       $ascii .= sprintf('\u%04s', bin2hex($utf16));       break;     }    }    return '"'.$ascii.'"';   case 'array':    /*    * As per JSON spec if any array key is not an integer    * we must treat the the whole array as an object. We    * also try to catch a sparsely populated associative    * array with numeric keys here because some JS engines    * will create an array with empty indexes up to    * max_index which can cause memory issues and because    * the keys, which may be relevant, will be remapped    * otherwise.    *    * As per the ECMA and JSON specification an object may    * have any string as a property. Unfortunately due to    * a hole in the ECMA specification if the key is a    * ECMA reserved word or starts with a digit the    * parameter is only accessible using ECMAScript's    * bracket notation.    */    // treat as a JSON object    if (is_array($var) && count($var) && (array_keys($var) !== range(0, sizeof($var) - 1))) {     $properties = array_map(array($this, 'name_value'),           array_keys($var),           array_values($var));     foreach($properties as $property) {      if(Services_JSON::isError($property)) {       return $property;      }     }     return '{' . join(',', $properties) . '}';    }    // treat it like a regular array    $elements = array_map(array($this, 'encode'), $var);    foreach($elements as $element) {     if(Services_JSON::isError($element)) {      return $element;     }    }    return '[' . join(',', $elements) . ']';   case 'object':    $vars = get_object_vars($var);    $properties = array_map(array($this, 'name_value'),          array_keys($vars),          array_values($vars));    foreach($properties as $property) {     if(Services_JSON::isError($property)) {      return $property;     }    }    return '{' . join(',', $properties) . '}';   default:    return ($this->use & SERVICES_JSON_SUPPRESS_ERRORS)     ? 'null'     : new Services_JSON_Error(gettype($var)." can not be encoded as JSON string");  } } /** * array-walking function for use in generating JSON-formatted name-value pairs * * @param string $name name of key to use * @param mixed $value reference to an array element to be encoded * * @return string JSON-formatted name-value pair, like '"name":value' * @access private */ function name_value($name, $value) {  $encoded_value = $this->encode($value);  if(Services_JSON::isError($encoded_value)) {   return $encoded_value;  }  return $this->encode(strval($name)) . ':' . $encoded_value; } /** * reduce a string by removing leading and trailing comments and whitespace * * @param $str string  string value to strip of comments and whitespace * * @return string string value stripped of comments and whitespace * @access private */ function reduce_string($str) {  $str = preg_replace(array(    // eliminate single line comments in '// ...' form    '#^\s*//(.+)$#m',    // eliminate multi-line comments in '/* ... */' form, at start of string    '#^\s*/\*(.+)\*/#Us',    // eliminate multi-line comments in '/* ... */' form, at end of string    '#/\*(.+)\*/\s*$#Us'   ), '', $str);  // eliminate extraneous space  return trim($str); } /** * decodes a JSON string into appropriate variable * * @param string $str JSON-formatted string * * @return mixed number, boolean, string, array, or object *     corresponding to given JSON input string. *     See argument 1 to Services_JSON() above for object-output behavior. *     Note that decode() always returns strings *     in ASCII or UTF-8 format! * @access public */ function decode($str) {  $str = $this->reduce_string($str);  switch (strtolower($str)) {   case 'true':    return true;   case 'false':    return false;   case 'null':    return null;   default:    $m = array();    if (is_numeric($str)) {     // Lookie-loo, it's a number     // This would work on its own, but I'm trying to be     // good about returning integers where appropriate:     // return (float)$str;     // Return float or int, as appropriate     return ((float)$str == (integer)$str)      ? (integer)$str      : (float)$str;    } elseif (preg_match('/^("|\').*(\1)$/s', $str, $m) && $m[1] == $m[2]) {     // STRINGS RETURNED IN UTF-8 FORMAT     $delim = substr($str, 0, 1);     $chrs = substr($str, 1, -1);     $utf8 = '';     $strlen_chrs = strlen($chrs);     for ($c = 0; $c < $strlen_chrs; ++$c) {      $substr_chrs_c_2 = substr($chrs, $c, 2);      $ord_chrs_c = ord($chrs{$c});      switch (true) {       case $substr_chrs_c_2 == '\b':        $utf8 .= chr(0x08);        ++$c;        break;       case $substr_chrs_c_2 == '\t':        $utf8 .= chr(0x09);        ++$c;        break;       case $substr_chrs_c_2 == '\n':        $utf8 .= chr(0x0A);        ++$c;        break;       case $substr_chrs_c_2 == '\f':        $utf8 .= chr(0x0C);        ++$c;        break;       case $substr_chrs_c_2 == '\r':        $utf8 .= chr(0x0D);        ++$c;        break;       case $substr_chrs_c_2 == '\\"':       case $substr_chrs_c_2 == '\\\'':       case $substr_chrs_c_2 == '\\\\':       case $substr_chrs_c_2 == '\\/':        if (($delim == '"' && $substr_chrs_c_2 != '\\\'') ||         ($delim == "'" && $substr_chrs_c_2 != '\\"')) {         $utf8 .= $chrs{++$c};        }        break;       case preg_match('/\\\u[0-9A-F]{4}/i', substr($chrs, $c, 6)):        // single, escaped unicode character        $utf16 = chr(hexdec(substr($chrs, ($c + 2), 2)))          . chr(hexdec(substr($chrs, ($c + 4), 2)));        $utf8 .= $this->utf162utf8($utf16);        $c += 5;        break;       case ($ord_chrs_c >= 0x20) && ($ord_chrs_c <= 0x7F):        $utf8 .= $chrs{$c};        break;       case ($ord_chrs_c & 0xE0) == 0xC0:        // characters U-00000080 - U-000007FF, mask 110XXXXX        //see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8        $utf8 .= substr($chrs, $c, 2);        ++$c;        break;       case ($ord_chrs_c & 0xF0) == 0xE0:        // characters U-00000800 - U-0000FFFF, mask 1110XXXX        // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8        $utf8 .= substr($chrs, $c, 3);        $c += 2;        break;       case ($ord_chrs_c & 0xF8) == 0xF0:        // characters U-00010000 - U-001FFFFF, mask 11110XXX        // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8        $utf8 .= substr($chrs, $c, 4);        $c += 3;        break;       case ($ord_chrs_c & 0xFC) == 0xF8:        // characters U-00200000 - U-03FFFFFF, mask 111110XX        // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8        $utf8 .= substr($chrs, $c, 5);        $c += 4;        break;       case ($ord_chrs_c & 0xFE) == 0xFC:        // characters U-04000000 - U-7FFFFFFF, mask 1111110X        // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8        $utf8 .= substr($chrs, $c, 6);        $c += 5;        break;      }     }     return $utf8;    } elseif (preg_match('/^\[.*\]$/s', $str) || preg_match('/^\{.*\}$/s', $str)) {     // array, or object notation     if ($str{0} == '[') {      $stk = array(SERVICES_JSON_IN_ARR);      $arr = array();     } else {      if ($this->use & SERVICES_JSON_LOOSE_TYPE) {       $stk = array(SERVICES_JSON_IN_OBJ);       $obj = array();      } else {       $stk = array(SERVICES_JSON_IN_OBJ);       $obj = new stdClass();      }     }     array_push($stk, array('what' => SERVICES_JSON_SLICE,           'where' => 0,           'delim' => false));     $chrs = substr($str, 1, -1);     $chrs = $this->reduce_string($chrs);     if ($chrs == '') {      if (reset($stk) == SERVICES_JSON_IN_ARR) {       return $arr;      } else {       return $obj;      }     }     //print("\nparsing {$chrs}\n");     $strlen_chrs = strlen($chrs);     for ($c = 0; $c <= $strlen_chrs; ++$c) {      $top = end($stk);      $substr_chrs_c_2 = substr($chrs, $c, 2);      if (($c == $strlen_chrs) || (($chrs{$c} == ',') && ($top['what'] == SERVICES_JSON_SLICE))) {       // found a comma that is not inside a string, array, etc.,       // OR we've reached the end of the character list       $slice = substr($chrs, $top['where'], ($c - $top['where']));       array_push($stk, array('what' => SERVICES_JSON_SLICE, 'where' => ($c + 1), 'delim' => false));       //print("Found split at {$c}: ".substr($chrs, $top['where'], (1 + $c - $top['where']))."\n");       if (reset($stk) == SERVICES_JSON_IN_ARR) {        // we are in an array, so just push an element onto the stack        array_push($arr, $this->decode($slice));       } elseif (reset($stk) == SERVICES_JSON_IN_OBJ) {        // we are in an object, so figure        // out the property name and set an        // element in an associative array,        // for now        $parts = array();        if (preg_match('/^\s*(["\'].*[^\\\]["\'])\s*:\s*(\S.*),?$/Uis', $slice, $parts)) {         // "name":value pair         $key = $this->decode($parts[1]);         $val = $this->decode($parts[2]);         if ($this->use & SERVICES_JSON_LOOSE_TYPE) {          $obj[$key] = $val;         } else {          $obj->$key = $val;         }        } elseif (preg_match('/^\s*(\w+)\s*:\s*(\S.*),?$/Uis', $slice, $parts)) {         // name:value pair, where name is unquoted         $key = $parts[1];         $val = $this->decode($parts[2]);         if ($this->use & SERVICES_JSON_LOOSE_TYPE) {          $obj[$key] = $val;         } else {          $obj->$key = $val;         }        }       }      } elseif ((($chrs{$c} == '"') || ($chrs{$c} == "'")) && ($top['what'] != SERVICES_JSON_IN_STR)) {       // found a quote, and we are not inside a string       array_push($stk, array('what' => SERVICES_JSON_IN_STR, 'where' => $c, 'delim' => $chrs{$c}));       //print("Found start of string at {$c}\n");      } elseif (($chrs{$c} == $top['delim']) &&         ($top['what'] == SERVICES_JSON_IN_STR) &&         ((strlen(substr($chrs, 0, $c)) - strlen(rtrim(substr($chrs, 0, $c), '\\'))) % 2 != 1)) {       // found a quote, we're in a string, and it's not escaped       // we know that it's not escaped becase there is _not_ an       // odd number of backslashes at the end of the string so far       array_pop($stk);       //print("Found end of string at {$c}: ".substr($chrs, $top['where'], (1 + 1 + $c - $top['where']))."\n");      } elseif (($chrs{$c} == '[') &&         in_array($top['what'], array(SERVICES_JSON_SLICE, SERVICES_JSON_IN_ARR, SERVICES_JSON_IN_OBJ))) {       // found a left-bracket, and we are in an array, object, or slice       array_push($stk, array('what' => SERVICES_JSON_IN_ARR, 'where' => $c, 'delim' => false));       //print("Found start of array at {$c}\n");      } elseif (($chrs{$c} == ']') && ($top['what'] == SERVICES_JSON_IN_ARR)) {       // found a right-bracket, and we're in an array       array_pop($stk);       //print("Found end of array at {$c}: ".substr($chrs, $top['where'], (1 + $c - $top['where']))."\n");      } elseif (($chrs{$c} == '{') &&         in_array($top['what'], array(SERVICES_JSON_SLICE, SERVICES_JSON_IN_ARR, SERVICES_JSON_IN_OBJ))) {       // found a left-brace, and we are in an array, object, or slice       array_push($stk, array('what' => SERVICES_JSON_IN_OBJ, 'where' => $c, 'delim' => false));       //print("Found start of object at {$c}\n");      } elseif (($chrs{$c} == '}') && ($top['what'] == SERVICES_JSON_IN_OBJ)) {       // found a right-brace, and we're in an object       array_pop($stk);       //print("Found end of object at {$c}: ".substr($chrs, $top['where'], (1 + $c - $top['where']))."\n");      } elseif (($substr_chrs_c_2 == '/*') &&         in_array($top['what'], array(SERVICES_JSON_SLICE, SERVICES_JSON_IN_ARR, SERVICES_JSON_IN_OBJ))) {       // found a comment start, and we are in an array, object, or slice       array_push($stk, array('what' => SERVICES_JSON_IN_CMT, 'where' => $c, 'delim' => false));       $c++;       //print("Found start of comment at {$c}\n");      } elseif (($substr_chrs_c_2 == '*/') && ($top['what'] == SERVICES_JSON_IN_CMT)) {       // found a comment end, and we're in one now       array_pop($stk);       $c++;       for ($i = $top['where']; $i <= $c; ++$i)        $chrs = substr_replace($chrs, ' ', $i, 1);       //print("Found end of comment at {$c}: ".substr($chrs, $top['where'], (1 + $c - $top['where']))."\n");      }     }     if (reset($stk) == SERVICES_JSON_IN_ARR) {      return $arr;     } elseif (reset($stk) == SERVICES_JSON_IN_OBJ) {      return $obj;     }    }  } } /**  * @todo Ultimately, this should just call PEAR::isError()  */ function isError($data, $code = null) {  if (class_exists('pear')) {   return PEAR::isError($data, $code);  } elseif (is_object($data) && (get_class($data) == 'services_json_error' || is_subclass_of($data, 'services_json_error'))) {   return true;  }  return false; }}if (class_exists('PEAR_Error')) { class Services_JSON_Error extends PEAR_Error {  function Services_JSON_Error($message = 'unknown error', $code = null, $mode = null, $options = null, $userinfo = null)  {   parent::PEAR_Error($message, $code, $mode, $options, $userinfo);  } }} else { /**  * @todo Ultimately, this class shall be descended from PEAR_Error  */ class Services_JSON_Error {  function Services_JSON_Error($message = 'unknown error', $code = null, $mode = null, $options = null, $userinfo = null)  {  } }}?>

希望本文所述对大家的php程序设计有所帮助。

您可能感兴趣的文章:

  • 关于JSON以及JSON在PHP中的应用技巧
  • PHP json_decode函数详细解析
  • php判断是否为json格式的方法
  • PHP处理Json字符串解码返回NULL的解决方法
  • php返回json数据函数实例
  • php json_encode()函数返回json数据实例代码
  • php json转换成数组形式代码分享
  • PHP使用json_encode函数时不转义中文的解决方法
  • ThinkPHP中使用ajax接收json数据的方法
  • php中JSON的使用与转换
  • php解析http获取的json字符串变量总是空白null
  • php数组转成json格式的方法
  • php简单实现查询数据库返回json数据
  • 浅谈PHP中JSON数据操作
  • php实现数组中索引关联数据转换成json对象的方法
  • php实现json编码的方法
  • PHP去掉json字符串中的反斜杠\及去掉双引号前的反斜杠
  • JSON用法之将PHP数组转JS数组,JS如何接收PHP数组
  • PHP的serialize序列化数据以及JSON格式化数据分析
  • PHP中JSON的应用技巧


  • 上一条:
    php类自动加载器实现方法
    下一条:
    php无序树实现方法
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 用Time Warden监控PHP中的代码处理时间(0个评论)
    • 在PHP中使用array_pop + yield实现读取超大型目录功能示例(0个评论)
    • Property Hooks RFC在PHP 8.4中越来越接近现实(0个评论)
    • 近期文章
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(95个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-11
    • 2017-12
    • 2018-01
    • 2018-02
    • 2018-03
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-09
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    • 2024-09
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客