Heim >Backend-Entwicklung >PHP-Problem >So implementieren Sie das Hochladen und Herunterladen von Dateien in PHP

So implementieren Sie das Hochladen und Herunterladen von Dateien in PHP

藏色散人
藏色散人Original
2020-10-29 09:28:063734Durchsuche

So implementieren Sie das Hochladen und Herunterladen von Dateien in PHP: Erstellen Sie zuerst die Formularseite, laden Sie dann die Clientdatei auf den Server hoch und verschieben Sie schließlich die serverseitige Datei in das angegebene Verzeichnis.

So implementieren Sie das Hochladen und Herunterladen von Dateien in PHP

Empfohlen: „PHP-Video-Tutorial

PHP-Implementierung des Datei-Uploads und -Downloads

1. Upload-Prinzip und Konfiguration

1.1-Prinzip

Laden Sie Client-Dateien auf den Server hoch Ende und verschieben Sie dann die serverseitigen Dateien (temporäre Dateien) in das angegebene Verzeichnis.

1.2 Client-Konfiguration

Erforderlich: (Upload-Datei auswählen);

Im Einzelnen: Die Sendemethode ist POST, fügen Sie das Attribut enctype="multipart/form-data" hinzu, beide sind unverzichtbar (hier gibt es jedoch Vor- und Nachteile der Koexistenz). schränkt auch die Upload-Methode und den Aufruf der hochgeladenen Datei usw. ein, was später erwähnt wird)

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<form action="doAction.php" method="post" enctype="multipart/form-data">
请选择您要上传的文件:
<input type="file" name="myFile" /><br/>
<input type="submit" value="上传"/>
</form>
<?php

?>
</body>
</html>

Zuerst ist die Formularseite (bitte ignorieren Sie automatisch die Front-End-Probleme ...), der Schlüssel sind die Attribute von das Formular; das andere ist die Eingabe, die Type="file" verwendet (was die leistungsstarke Erweiterung von PHP usw. widerspiegelt).

Dann doAction

<?php
//$_FILES:文件上传变量
//print_r($_FILES);
$filename=$_FILES[&#39;myFile&#39;][&#39;name&#39;];
$type=$_FILES[&#39;myFile&#39;][&#39;type&#39;];
$tmp_name=$_FILES[&#39;myFile&#39;][&#39;tmp_name&#39;];
$size=$_FILES[&#39;myFile&#39;][&#39;size&#39;];
$error=$_FILES[&#39;myFile&#39;][&#39;error&#39;];

//将服务器上的临时文件移动到指定位置
//方法一move_upload_file($tmp_name,$destination)
//move_uploaded_file($tmp_name, "uploads/".$filename);//文件夹应提前建立好,不然报错
//方法二copy($src,$des)
//以上两个函数都是成功返回真,否则返回false
//copy($tmp_name, "copies/".$filename);
//注意,不能两个方法都对临时文件进行操作,临时文件似乎操作完就没了,我们试试反过来
copy($tmp_name, "copies/".$filename);
move_uploaded_file($tmp_name, "uploads/".$filename);
//能够实现,说明move那个函数基本上相当于剪切;copy就是copy,临时文件还在

//另外,错误信息也是不一样的,遇到错误可以查看或者直接报告给用户
if ($error==0) {
  echo "上传成功!";
}else{
  switch ($error){
    case 1:
      echo "超过了上传文件的最大值,请上传2M以下文件";
      break;
    case 2:
      echo "上传文件过多,请一次上传20个及以下文件!";
      break;
    case 3:
      echo "文件并未完全上传,请再次尝试!";
      break;
    case 4:
      echo "未选择上传文件!";
      break;
    case 5:
      echo "上传文件为0";
      break;
  }
}

Schauen Sie sich zuerst die Informationen von print_r($_FILES) an

Array
(
  [myFile] => Array
    (
      [name] => 梁博_简历.doc
      [type] => application/msword
      [tmp_name] => D:\wamp\tmp\php1D78.tmp
      [error] => 0
      [size] => 75776
    )

)

Sie erhalten also ein zweidimensionales Array, das sind alles grundlegende Dinge (tatsächlich möchte ich die Dimension reduzieren). und dann verwenden);

Es ist im Grunde etwas, das Sie auf einen Blick verstehen können. Es gibt zwei wichtige Punkte: tmp_name temporärer Dateiname; Codename, Sie können ihn später verwenden Schauen Sie sich den letzten Teil von doAction an und verwenden Sie die Fehlermeldung, um den Benutzern Feedback zu geben. Es muss erklärt werden, warum der Fehler gemeldet wird und was die Fehlermeldung ist Grund für die Fehlermeldung:

Grundsätzlich überschreitet es die Konfiguration des Servers zum Hochladen von Dateien oder entspricht dieser nicht, also auf der Serverseite. Welche Konfigurationen gibt es?

Erwägen Sie zunächst, das hochzuladen, was wir verwendet haben? POST, Upload

Suchen Sie also nach diesen Elementen in php.ini:

file_upload:On

upload_tmp_dir=——Temporäres Dateispeicherverzeichnis;

upload_max_filesize=2M

max_file_uploads=20——Die maximal zulässige Datei, die hochgeladen werden darf auf einmal Menge (beachten Sie den Unterschied zum oben genannten, denken Sie nicht darüber nach, ob es eine Größe gibt)

post_max_size=8M – der maximale Wert der per Post-Methode gesendeten Daten

Andere verwandte Konfigurationen

max_exectuion_time= -1 – maximale Ausführungszeit, verhindert, dass das Programm Serverressourcen belegt; es geht um die Konfiguration von Ressourcen.

--Die Fehlernummer

Das Folgende (faul) stammt aus http://blog.sina.com.cn/s/blog_3cdfaea201008utf.html

UPLOAD_ERR_OK Wert: 0; Es ist kein Fehler aufgetreten und die Datei wurde erfolgreich hochgeladen.

UPLOAD_ERR_INI_SIZE Wert: 1; Die hochgeladene Datei überschreitet den Grenzwert der Option upload_max_filesize in php.ini.

UPLOAD_ERR_FORM_SIZE Wert: 2; Die Größe der hochgeladenen Datei überschreitet den durch die Option MAX_FILE_SIZE im HTML-Formular angegebenen Wert.

UPLOAD_ERR_PARTIAL Wert: 3; Nur ein Teil der Datei wurde hochgeladen.

UPLOAD_ERR_NO_FILE Wert: 4; Es wurde keine Datei hochgeladen.

Hinweis: Bei dieser Fehlermeldung handelt es sich um die im ersten Schritt hochgeladenen Informationen, also beim Hochladen in einen temporären Ordner, nicht beim Verschieben oder Kopieren. 2. Einschränkungen beim Hochladen 1. Der HTML-Code ist „sichtbar“; zweitens funktioniert er oft nicht (den Grund habe ich nicht gefunden, aber wegen des ersten möchte ich ihn auch aufgeben, weiß es einfach.

2.2 Server -seitige Einschränkungen
  • Hauptsächlich Größe und Typ begrenzen, und dann gibt es einen Weg
  • <form action="doAction2.php" method="post" enctype="multipart/form-data">
    <input type="hidden" name="MAX_FILE_SIZE" value="101321" />
  • 2.3 Kapselung
  • Funktion
  • <input type="file" name="myFile" accept="image/jpeg,image/gif,text/html"/><br/>
    <input type="submit" value="上传"/>
    </form>
  • Aufruf
  • <?php
    header(&#39;content-type:text/html;charset=utf-8&#39;);
    //接受文件,临时文件信息
    $fileinfo=$_FILES["myFile"];//降维操作
    $filename=$fileinfo["name"];
    $tmp_name=$fileinfo["tmp_name"];
    $size=$fileinfo["size"];
    $error=$fileinfo["error"];
    $type=$fileinfo["type"];
    
    //服务器端设定限制
    $maxsize=10485760;//10M,10*1024*1024
    $allowExt=array(&#39;jpeg&#39;,&#39;jpg&#39;,&#39;png&#39;,&#39;tif&#39;);//允许上传的文件类型(拓展名
    $ext=pathinfo($filename,PATHINFO_EXTENSION);//提取上传文件的拓展名
    
    //目的信息
    $path="uploads";
    if (!file_exists($path)) {  //当目录不存在,就创建目录
      mkdir($path,0777,true);
      chmod($path, 0777);
    }
    //$destination=$path."/".$filename;
    //得到唯一的文件名!防止因为文件名相同而产生覆盖
    $uniName=md5(uniqid(microtime(true),true)).$ext;//md5加密,uniqid产生唯一id,microtime做前缀
    
    
    if ($error==0) {
      if ($size>$maxsize) {
        exit("上传文件过大!");
      }
      if (!in_array($ext, $allowExt)) {
        exit("非法文件类型");
      }
      if (!is_uploaded_file($tmp_name)) {
        exit("上传方式有误,请使用post方式");
      }
      if (@move_uploaded_file($tmp_name, $uniName)) {//@错误抑制符,不让用户看到警告
        echo "文件".$filename."上传成功!";
      }else{
        echo "文件".$filename."上传失败!";
      }
      //判断是否为真实图片(防止伪装成图片的病毒一类的
      if (!getimagesize($tmp_name)) {//getimagesize真实返回数组,否则返回false
        exit("不是真正的图片类型");
      }
    
    }else{
      switch ($error){
        case 1:
          echo "超过了上传文件的最大值,请上传2M以下文件";
          break;
        case 2:
          echo "上传文件过多,请一次上传20个及以下文件!";
          break;
        case 3:
          echo "文件并未完全上传,请再次尝试!";
          break;
        case 4:
          echo "未选择上传文件!";
          break;
        case 7:
          echo "没有临时文件夹";
          break;
      }
    }
    这里,具体实现都有注释,每一步其实都可以自己
  • 3. Implementierung des Hochladens mehrerer Dateien

3.1 Verwendung einzelner Dateikapseln ulation

<?php
function uploadFile($fileInfo,$path,$allowExt,$maxSize){

$filename=$fileInfo["name"];
$tmp_name=$fileInfo["tmp_name"];
$size=$fileInfo["size"];
$error=$fileInfo["error"];
$type=$fileInfo["type"];

//服务器端设定限制

$ext=pathinfo($filename,PATHINFO_EXTENSION);

//目的信息
if (!file_exists($path)) {  
  mkdir($path,0777,true);
  chmod($path, 0777);
}
$uniName=md5(uniqid(microtime(true),true)).&#39;.&#39;.$ext;
$destination=$path."/".$uniName;


if ($error==0) {
  if ($size>$maxSize) {
    exit("上传文件过大!");
  }
  if (!in_array($ext, $allowExt)) {
    exit("非法文件类型");
  }
  if (!is_uploaded_file($tmp_name)) {
    exit("上传方式有误,请使用post方式");
  }
  //判断是否为真实图片(防止伪装成图片的病毒一类的
  if (!getimagesize($tmp_name)) {//getimagesize真实返回数组,否则返回false
    exit("不是真正的图片类型");
  }
  if (@move_uploaded_file($tmp_name, $destination)) {//@错误抑制符,不让用户看到警告
    echo "文件".$filename."上传成功!";
  }else{
    echo "文件".$filename."上传失败!";
  }
  

}else{
  switch ($error){
    case 1:
      echo "超过了上传文件的最大值,请上传2M以下文件";
      break;
    case 2:
      echo "上传文件过多,请一次上传20个及以下文件!";
      break;
    case 3:
      echo "文件并未完全上传,请再次尝试!";
      break;
    case 4:
      echo "未选择上传文件!";
      break;
    case 7:
      echo "没有临时文件夹";
      break;
  }
}
return $destination;
}
Die Idee hier ist von print_r($_FILES). Finden Sie es, drucken Sie es aus und sehen Sie, dass es ein zweidimensionales Array ist. Es ist sehr einfach.

Ändern Sie die Definition der Funktion oben Geben Sie einige Standardwerte an

rrree

Das ist einfach, aber es gibt einige Probleme

Es ist kein Problem, 4 Bilder normal hochzuladen, aber wenn der Exit in der Funktion aktiviert ist, wird er sofort gestoppt Andere Bilder können nicht hochgeladen werden.

Die aktualisierte Version des Pakets

ist darauf ausgelegt, mehrere Uploads zu ermöglichen.

Schreiben Sie zunächst eine statische Datei wie diese kann ein dreidimensionales Array erhalten

Es ist kompliziert, aber die Komplexität ist regelmäßig und die Werte sind alle zusammen, es ist für uns sehr praktisch, den Wert zu erhalten

Also holen wir uns zuerst die Datei Informationen und wandeln Sie sie in eine einzige Dateiverarbeitung um

function getFiles(){
  $i=0;
  foreach($_FILES as $file){
    if(is_string($file[&#39;name&#39;])){ //单文件判定
      $files[$i]=$file;
      $i++;
    }elseif(is_array($file[&#39;name&#39;])){
      foreach($file[&#39;name&#39;] as $key=>$val){ //我的天,这个$key用的diao
        $files[$i][&#39;name&#39;]=$file[&#39;name&#39;][$key];
        $files[$i][&#39;type&#39;]=$file[&#39;type&#39;][$key];
        $files[$i][&#39;tmp_name&#39;]=$file[&#39;tmp_name&#39;][$key];
        $files[$i][&#39;error&#39;]=$file[&#39;error&#39;][$key];
        $files[$i][&#39;size&#39;]=$file[&#39;size&#39;][$key];
        $i++;
      }
    }
  }
  return $files;
  
}

然后之前的那种exit错误,就把exit改一下就好了,这里用res

function uploadFile($fileInfo,$path=&#39;./uploads&#39;,$flag=true,$maxSize=1048576,$allowExt=array(&#39;jpeg&#39;,&#39;jpg&#39;,&#39;png&#39;,&#39;gif&#39;)){
  //$flag=true;
  //$allowExt=array(&#39;jpeg&#39;,&#39;jpg&#39;,&#39;gif&#39;,&#39;png&#39;);
  //$maxSize=1048576;//1M
  //判断错误号
  $res=array();
  if($fileInfo[&#39;error&#39;]===UPLOAD_ERR_OK){
    //检测上传得到小
    if($fileInfo[&#39;size&#39;]>$maxSize){
      $res[&#39;mes&#39;]=$fileInfo[&#39;name&#39;].&#39;上传文件过大&#39;;
    }
    $ext=getExt($fileInfo[&#39;name&#39;]);
    //检测上传文件的文件类型
    if(!in_array($ext,$allowExt)){
      $res[&#39;mes&#39;]=$fileInfo[&#39;name&#39;].&#39;非法文件类型&#39;;
    }
    //检测是否是真实的图片类型
    if($flag){
      if(!getimagesize($fileInfo[&#39;tmp_name&#39;])){
        $res[&#39;mes&#39;]=$fileInfo[&#39;name&#39;].&#39;不是真实图片类型&#39;;
      }
    }
    //检测文件是否是通过HTTP POST上传上来的
    if(!is_uploaded_file($fileInfo[&#39;tmp_name&#39;])){
      $res[&#39;mes&#39;]=$fileInfo[&#39;name&#39;].&#39;文件不是通过HTTP POST方式上传上来的&#39;;
    }
    if($res) return $res;
    //$path=&#39;./uploads&#39;;
    if(!file_exists($path)){
      mkdir($path,0777,true);
      chmod($path,0777);
    }
    $uniName=getUniName();
    $destination=$path.&#39;/&#39;.$uniName.&#39;.&#39;.$ext;
    if(!move_uploaded_file($fileInfo[&#39;tmp_name&#39;],$destination)){
      $res[&#39;mes&#39;]=$fileInfo[&#39;name&#39;].&#39;文件移动失败&#39;;
    }
    $res[&#39;mes&#39;]=$fileInfo[&#39;name&#39;].&#39;上传成功&#39;;
    $res[&#39;dest&#39;]=$destination;
    return $res;
    
  }else{
    //匹配错误信息
    switch ($fileInfo [&#39;error&#39;]) {
      case 1 :
        $res[&#39;mes&#39;] = &#39;上传文件超过了PHP配置文件中upload_max_filesize选项的值&#39;;
        break;
      case 2 :
        $res[&#39;mes&#39;] = &#39;超过了表单MAX_FILE_SIZE限制的大小&#39;;
        break;
      case 3 :
        $res[&#39;mes&#39;] = &#39;文件部分被上传&#39;;
        break;
      case 4 :
        $res[&#39;mes&#39;] = &#39;没有选择上传文件&#39;;
        break;
      case 6 :
        $res[&#39;mes&#39;] = &#39;没有找到临时目录&#39;;
        break;
      case 7 :
      case 8 :
        $res[&#39;mes&#39;] = &#39;系统错误&#39;;
        break;
    }
    return $res;
  }
}

里面封装了两个小的

function getExt($filename){
  return strtolower(pathinfo($filename,PATHINFO_EXTENSION));
}

/**
 * 产生唯一字符串
 * @return string
 */
function getUniName(){
  return md5(uniqid(microtime(true),true));
}

然后静态中,用multiple属性实现多个文件的输入;

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<form action="doAction6.php" method="POST" enctype="multipart/form-data">
请选择您要上传的文件:<input type="file" name="myFile[]" multiple=&#39;multiple&#39; /><br/>
<input type="submit" value="上传"/>
</form>
</body>
</html>
doAction6
<?php 
//print_r($_FILES);
header("content-type:text/html;charset=utf-8");
require_once &#39;upFunc2.php&#39;;
require_once &#39;common.func.php&#39;;
$files=getFiles();
// print_r($files);
foreach($files as $fileInfo){
  $res=uploadFile($fileInfo);
  echo $res[&#39;mes&#39;],&#39;<br/>&#39;;
  $uploadFiles[]=@$res[&#39;dest&#39;];
}
$uploadFiles=array_values(array_filter($uploadFiles));
//print_r($uploadFiles);

这样子的几个文件,就实现比较强大的面向过程的上传文件的功能(学的叫一个心酸。。。);

四、面向对象的文件上传

<?php 
class upload{
  protected $fileName;
  protected $maxSize;
  protected $allowMime;
  protected $allowExt;
  protected $uploadPath;
  protected $imgFlag;
  protected $fileInfo;
  protected $error;
  protected $ext;
  /**
   * @param string $fileName
   * @param string $uploadPath
   * @param string $imgFlag
   * @param number $maxSize
   * @param array $allowExt
   * @param array $allowMime
   */
  public function __construct($fileName=&#39;myFile&#39;,$uploadPath=&#39;./uploads&#39;,$imgFlag=true,$maxSize=5242880,$allowExt=array(&#39;jpeg&#39;,&#39;jpg&#39;,&#39;png&#39;,&#39;gif&#39;),$allowMime=array(&#39;image/jpeg&#39;,&#39;image/png&#39;,&#39;image/gif&#39;)){
    $this->fileName=$fileName;
    $this->maxSize=$maxSize;
    $this->allowMime=$allowMime;
    $this->allowExt=$allowExt;
    $this->uploadPath=$uploadPath;
    $this->imgFlag=$imgFlag;
    $this->fileInfo=$_FILES[$this->fileName];
  }
  /**
   * 检测上传文件是否出错
   * @return boolean
   */
  protected function checkError(){
    if(!is_null($this->fileInfo)){
      if($this->fileInfo[&#39;error&#39;]>0){
        switch($this->fileInfo[&#39;error&#39;]){
          case 1:
            $this->error=&#39;超过了PHP配置文件中upload_max_filesize选项的值&#39;;
            break;
          case 2:
            $this->error=&#39;超过了表单中MAX_FILE_SIZE设置的值&#39;;
            break;
          case 3:
            $this->error=&#39;文件部分被上传&#39;;
            break;
          case 4:
            $this->error=&#39;没有选择上传文件&#39;;
            break;
          case 6:
            $this->error=&#39;没有找到临时目录&#39;;
            break;
          case 7:
            $this->error=&#39;文件不可写&#39;;
            break;
          case 8:
            $this->error=&#39;由于PHP的扩展程序中断文件上传&#39;;
            break;
            
        }
        return false;
      }else{
        return true;
      }
    }else{
      $this->error=&#39;文件上传出错&#39;;
      return false;
    }
  }
  /**
   * 检测上传文件的大小
   * @return boolean
   */
  protected function checkSize(){
    if($this->fileInfo[&#39;size&#39;]>$this->maxSize){
      $this->error=&#39;上传文件过大&#39;;
      return false;
    }
    return true;
  }
  /**
   * 检测扩展名
   * @return boolean
   */
  protected function checkExt(){
    $this->ext=strtolower(pathinfo($this->fileInfo[&#39;name&#39;],PATHINFO_EXTENSION));
    if(!in_array($this->ext,$this->allowExt)){
      $this->error=&#39;不允许的扩展名&#39;;
      return false;
    }
    return true;
  }
  /**
   * 检测文件的类型
   * @return boolean
   */
  protected function checkMime(){
    if(!in_array($this->fileInfo[&#39;type&#39;],$this->allowMime)){
      $this->error=&#39;不允许的文件类型&#39;;
      return false;
    }
    return true;
  }
  /**
   * 检测是否是真实图片
   * @return boolean
   */
  protected function checkTrueImg(){
    if($this->imgFlag){
      if(!@getimagesize($this->fileInfo[&#39;tmp_name&#39;])){
        $this->error=&#39;不是真实图片&#39;;
        return false;
      }
      return true;
    }
  }
  /**
   * 检测是否通过HTTP POST方式上传上来的
   * @return boolean
   */
  protected function checkHTTPPost(){
    if(!is_uploaded_file($this->fileInfo[&#39;tmp_name&#39;])){
      $this->error=&#39;文件不是通过HTTP POST方式上传上来的&#39;;
      return false;
    }
    return true;
  }
  /**
   *显示错误 
   */
  protected function showError(){
    exit(&#39;<span style="color:red">&#39;.$this->error.&#39;</span>&#39;);
  }
  /**
   * 检测目录不存在则创建
   */
  protected function checkUploadPath(){
    if(!file_exists($this->uploadPath)){
      mkdir($this->uploadPath,0777,true);
    }
  }
  /**
   * 产生唯一字符串
   * @return string
   */
  protected function getUniName(){
    return md5(uniqid(microtime(true),true));
  }
  /**
   * 上传文件
   * @return string
   */
  public function uploadFile(){
    if($this->checkError()&&$this->checkSize()&&$this->checkExt()&&$this->checkMime()&&$this->checkTrueImg()&&$this->checkHTTPPost()){
      $this->checkUploadPath();
      $this->uniName=$this->getUniName();
      $this->destination=$this->uploadPath.&#39;/&#39;.$this->uniName.&#39;.&#39;.$this->ext;
      if(@move_uploaded_file($this->fileInfo[&#39;tmp_name&#39;], $this->destination)){
        return $this->destination;
      }else{
        $this->error=&#39;文件移动失败&#39;;
        $this->showError();
      }
    }else{
      $this->showError();
    }
  }
}
<?php 
header(&#39;content-type:text/html;charset=utf-8&#39;);
require_once &#39;upload.class.php&#39;;
$upload=new upload(&#39;myFile1&#39;,&#39;imooc&#39;);
$dest=$upload->uploadFile();
echo $dest;

四、下载

对于浏览器不识别的,可以直接下载,但对于能识别的,需要多一两步

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>Insert title here</title>
</head>
<body>
<a href="1.rar">下载1.rar</a>
<br />
<a href="1.jpg">下载1.jpg</a>
<br />
<a href="doDownload.php?filename=1.jpg">通过程序下载1.jpg</a>
<br />
<a href="doDownload.php?filename=../upload/nv.jpg">下载nv.jpg</a>
<?php

?>
</body>
</html>
<?php 
$filename=$_GET[&#39;filename&#39;];
header(&#39;content-disposition:attachment;filename=&#39;.basename($filename));
header(&#39;content-length:&#39;.filesize($filename));
readfile($filename);

Das obige ist der detaillierte Inhalt vonSo implementieren Sie das Hochladen und Herunterladen von Dateien in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn