ホームページ  >  記事  >  バックエンド開発  >  PHPアバターアップロードプレビュー例の詳細説明

PHPアバターアップロードプレビュー例の詳細説明

墨辰丷
墨辰丷オリジナル
2018-05-23 11:36:561621ブラウズ

この記事では主にPHPアバターのアップロードプレビューの例を詳しく紹介しますので、興味のある方は参考にしていただければ幸いです。

写真のアップロードは誰もがよく知っていますが、今後のプロジェクトでは、アバターのアップロードなどの更新ページの方法を使用した写真のアップロードは、アルバム内の写真を選択した後に行う必要があります。アップロードを確認します。フォームからアップロードされることはありません。送信をクリックしてアップロードを更新します。非同期の非更新アップロード画像と画像プレビューを 2 つ紹介します。1 つ目は、既製の Uploadfy プラグインを介してアップロードするもので、インターネット上に多くの例があります。

しかし、私が重点的に紹介するのは 2 番目の方法、Ajax を介して画像をアップロードする方法です。 Uploadfy プラグインを使用するには、デバイスが swf 形式の Flash をサポートしている必要があるため、最初の方法はほとんどの携帯電話では使用できません。まず、アップロードの原理について説明します。写真を選択した後、js を介してファイルのテキスト フィールドを制御し、Ajax を介して非同期にフォームを送信し、画像の位置を戻り値として使用し、js を使用して src を設定します。戻り値として img の属性を返します。

アップロードアバターエリア:

コード:


<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>

<link href="bootstrap-3.3.7-dist/css/bootstrap.min.css" rel="external nofollow" rel="stylesheet" type="text/css" />
<script src="bootstrap-3.3.7-dist/js/jquery-1.11.2.min.js"></script>
<script src="bootstrap-3.3.7-dist/js/bootstrap.min.js"></script>

<style type="text/css">
#yl{ width:200px; height:200px; background-image:url(img/avatar.png); background-size:200px 200px;}
#file{ width:200px; height:200px; float:left; opacity:0;}
.modal-content{ width:500px;}
.kk{ margin-left:130px;}
</style>

</head>

<body>
<!-- 按钮触发模态框 -->
<button class="btn btn-primary btn-lg" data-toggle="modal" data-target="#myModal">
  上传头像
</button>
<!-- 模态框(Modal) -->
<p class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
  <p class="modal-dialog">
    <p class="modal-content">
      <p class="modal-header">
        <button type="button" class="close" data-dismiss="modal" aria-hidden="true">
          ×
        </button>
        <h4 class="modal-title" id="myModalLabel">
          上传头像
        </h4>
      </p>
      <p class="modal-body">
        <form id="sc" action="upload.php" method="post" enctype="multipart/form-data" target="shangchuan">
  
  <input type="hidden" name="tp" value="" id="tp" />
  
  <p id="yl" class="kk">
    <input type="file" name="file" id="file" onchange="document.getElementById(&#39;sc&#39;).submit()" />
  </p>  
</form>
<iframe style="display:none" name="shangchuan" id="shangchuan">
</iframe>

      </p>
      <p class="modal-footer">
        <button type="button" class="btn btn-default" data-dismiss="modal">关闭
        </button>
        <!--<button type="button" class="btn btn-primary">
          提交更改
        </button>-->
        
      </p>
    </p><!-- /.modal-content -->
  </p><!-- /.modal -->
</p>


</body>

<script type="text/javascript">

//回调函数,调用该方法传一个文件路径,该变背景图
function showimg(url)
{
  var p = document.getElementById("yl");
  p.style.backgroundImage = "url("+url+")";
  
  document.getElementById("tp").value = url;
}
</script>
</html>


アップロード処理ページ:


<?php

if($_FILES["file"]["error"])
{
  echo $_FILES["file"]["error"];
}
else
{
  if(($_FILES["file"]["type"]=="image/jpeg" || $_FILES["file"]["type"]=="image/png")&& $_FILES["file"]["size"]<1024000000)
  {
    $fname = "./img/".date("YmdHis").$_FILES["file"]["name"];  
    
    $filename = iconv("UTF-8","gb2312",$fname);
    
    if(file_exists($filename))
    {
      echo "<script>alert(&#39;该文件已存在!&#39;);</script>";
    }
    else
    {
      move_uploaded_file($_FILES["file"]["tmp_name"],$filename);
      
      unlink($_POST["tp"]);
      
      echo "<script>parent.showimg(&#39;{$fname}&#39;);</script>";
    }
    
  }
}


原則:

Byフォーム form -data の multipart/form" " プロパティは、ファイルを wamp フォルダーの tmp ディレクトリに一時的に配置し、バックグラウンドの php プログラムを通じてシステムにファイルを保存します。

以上がこの記事の全内容です、皆様の学習のお役に立てれば幸いです。


関連する推奨事項:

PHP+jQuery+Ajax+Mysql ムード表現関数の実装方法_javascript スキル

js は、php_javascript スキルの strtotime() 関数と date() 関数を模倣します

JavaScriptを使用してPHPのurlencode関数とurldecode関数を実装する_JavaScriptスキル


以上がPHPアバターアップロードプレビュー例の詳細説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。