Heim  >  Artikel  >  WeChat-Applet  >  Tutorial zum Hochladen von WeChat-Applet-Entwicklungsbildern und zum Empfangen von Servern

Tutorial zum Hochladen von WeChat-Applet-Entwicklungsbildern und zum Empfangen von Servern

黄舟
黄舟Original
2017-01-20 17:30:274033Durchsuche

Dieses Mal werde ich das häufig verwendete Hochladen von Bildern in Miniprogrammen vorstellen.

Ich habe vor ein paar Tagen die Funktion zum Hochladen von Bildern ausprobiert und bin nicht weitergekommen. Werfen wir als Nächstes einen Blick auf die Upload-API von WeChat.

Tutorial zum Hochladen von WeChat-Applet-Entwicklungsbildern und zum Empfangen von Servern

Der Dateipfad hier ist der Speicherpfad des Bildes, und der Typ ist tatsächlich ein String, was bedeutet, dass jeweils nur ein Bild übertragen werden kann. Meine vorherige Schnittstelle Ich habe selbst ein halberfahrener PHP-Benutzer, daher kann ich die Schnittstelle zum Empfangen von Bildern nur selbst ändern.

Sehen Sie sich die Seitendarstellungen an

Tutorial zum Hochladen von WeChat-Applet-Entwicklungsbildern und zum Empfangen von Servern

Ein sehr häufiger Effekt beim Ändern des Avatars: Wählen Sie das Bild aus (machen Sie ein Foto) und laden Sie es dann hoch.

Das Folgende ist der Code

Der erste ist der WXML-Code des Miniprogramms

<view class="xd-container">
<form bindsubmit="bindSaveTap">
<image class="xd-img-user1" catchtap="chooseImageTap" src="{{logo}}"></image>
<view class="xd-view-section">
 <text class="xd-abs xd-flex-left xd-text-nick">昵称</text>
 <input name="nick_name" placeholder="请输入昵称" class="xd-input" value="{{userInfo.user_name}}"/>
</view>
<view class="xd-view-section1">
 <text class="xd-abs xd-flex-left xd-text-nick">宝宝性别</text>
 <radio-group class="xd-abs xd-radio-group" name="baby_sex">
 <label class="xd-label-radio" wx:for="{{sex_items}}" wx:key="item">
 <radio color="#3cc975" value="{{item.name}}" wx:if="{{item.name==userInfo.baby_sex}}" checked="true"/>
 <radio color="#3cc975" value="{{item.name}}" wx:else checked="false"/>
 <text class="xd-radio-text">{{item.value}}</text>
 </label>
 </radio-group>
</view>
<view class="xd-view-section1">
 <text class="xd-abs xd-flex-left xd-text-nick">宝宝年龄</text>
 <input placeholder="请输入年龄" wx:if="{{userInfo.baby_age != 0}}" value="{{userInfo.baby_age}}" class="xd-input"/>
 <input name="baby_age" placeholder="请输入年龄" wx:else value="" class="xd-input"/>
</view>
<button size="default" class="xd-abs xd-subBtn" formType="submit" hover-class="xd-subBtn-hover">保存</button>
</form>
</view>

Ich werde keinen CSS-Code veröffentlichen, sondern nur einige Stile.

Entsprechender JS-Code

var util = require(&#39;../../../utils/util.js&#39;)
var app = getApp()
Page({
 data: {
sex_items: [
 {name:&#39;1&#39;, value:&#39;小王子&#39;},
 {name:&#39;2&#39;, value:&#39;小公主&#39;},
 {name:&#39;0&#39;, value:&#39;尚无&#39;}
],
logo:null,
 
userInfo: {}
 },
 
 //事件处理函数
 bindViewTap: function() {
wx.navigateTo({
 // url: &#39;../logs/logs&#39;
// url: &#39;../load/load&#39;
})
 },
 onLoad: function () {
console.log(&#39;onLoad&#39;)
var that = this
//调用应用实例的方法获取全局数据
app.getUserInfo(function(userInfo){
 //更新数据
 console.log(userInfo);
 that.setData({
 userInfo:userInfo,
 logo:userInfo.logo
 })
})
 },
 
 bindSaveTap: function(e){
console.log(e)
var formData = {
 uid:util.getUserID(),
 user_name:e.detail.value.nick_name,
 baby_sex:e.detail.value.baby_sex,
 baby_age:e.detail.value.baby_age
}
 console.log(formData)
app.apiFunc.upload_file(app.apiUrl.modify_user, this.data.logo, &#39;photos&#39;, formData, 
function(res){
 console.log(res);
},
function(){
})
 }, 
 
 chooseImageTap: function(){
let _this = this;
wx.showActionSheet({
 itemList: [&#39;从相册中选择&#39;, &#39;拍照&#39;],
 itemColor: "#f7982a",
 success: function(res) {
 if (!res.cancel) {
 if(res.tapIndex == 0){
 _this.chooseWxImage(&#39;album&#39;)
 }else if(res.tapIndex == 1){
 _this.chooseWxImage(&#39;camera&#39;)
 }
 }
 }
})
 
 },
chooseWxImage:function(type){
let _this = this;
wx.chooseImage({
 sizeType: [&#39;original&#39;, &#39;compressed&#39;],
 sourceType: [type],
 success: function (res) {
 console.log(res);
 _this.setData({
 logo: res.tempFilePaths[0],
 })
 }
 })
 }
})

Erläutert hauptsächlich den JS-Code

1. Die Methode „ChooseImageTap“

wird verwendet, um ein ausgewähltes Bild anzuzeigen und Das Popup-Fenster zum Aufnehmen von Bildern verwendet showActionSheet, eine interaktive Seiten-API von WeChat. Klicken Sie, um die detaillierte Verwendung anzuzeigen

Bedienmenü anzeigen

2. Wählen Sie die WxImage-Methode

Wird hauptsächlich zum Auswählen von Bildern und zum Empfangen der Bildpfad-Rückrufüberwachung verwendet. Klicken Sie hier, um die detaillierte Verwendung anzuzeigen

Wählen Sie Bilder aus dem lokalen Album aus oder verwenden Sie die Kamera zum Aufnehmen von Bildern

3. Hochladen

Im Erfolgsrückruf der Methode „chooseWxImage“ können wir sehen, dass ich dem Logo den zurückgegebenen Bildpfad „res.tempFilePaths[0]“ zugewiesen habe Die UploadFile-Methode von WeChat ist, dass ich sie gekapselt und in upload_file umgewandelt habe.

uploadFile-Methode

//上传文件
function upload_file(url, filePath, name, formData, success, fail) {
console.log(&#39;a=&#39;+filePath)
wx.uploadFile({
 url: rootUrl + url,
 filePath:filePath,
 name:name,
 header: {
 &#39;content-type&#39;:&#39;multipart/form-data&#39;
 }, // 设置请求的 header
 formData: formData, // HTTP 请求中其他额外的 form data
 success: function(res){
 console.log(res);
 if(res.statusCode ==200 && !res.data.result_code){
 typeof success == "function" && success(res.data);
 }else{
 typeof fail == "function" && fail(res);
 }
 },
 fail: function(res) {
 console.log(res);
 typeof fail == "function" && fail(res);
  }
 })
}

filePath ist die Logo-Variable, die wir in upload_file übergeben haben, was den absoluten Pfad des Bildes darstellt.

Der Bildempfangscode des Servers

Wer meinen vorherigen Artikel zum Anmeldevorgang gelesen hat, weiß, dass mein Server das PHP-Framework Laravel verwendet.

Hier werde ich nur den Code zum Empfangen des Bildes veröffentlichen

if(!empty($_FILES[&#39;photos&#39;])){
  $up_arr[&#39;logo&#39;] = upload_logo(&#39;photos&#39;,&#39;manage/images/user&#39;,&#39;logo&#39;,$user_id,0);
  $up_arr[&#39;logo&#39;] = $up_arr[&#39;logo&#39;][0];
  $user_info[&#39;logo&#39;] = $Server_Http_Path . $up_arr[&#39;logo&#39;];
}

Die Kernmethode befindet sich in upload_log.

Bilder empfangen und speichern

if( !function_exists(&#39;upload_logo&#39;)){
 function upload_logo( $key_name=&#39;photos&#39;, $logo_path=&#39;manage/images/nurse&#39;, $pre_name=&#39;logo&#39;, $salt=&#39;20160101&#39;,$encode = 1,$make=0 ){
  $result_arr = array();
  global $Server_Http_Path,$App_Error_Conf;
  //分文件夹保存 
  $date_info = getdate();
  $year = $date_info[&#39;year&#39;];
  $mon = $date_info[&#39;mon&#39;];
  $day = $date_info[&#39;mday&#39;];
  $logo_path = sprintf("%s/%s/%s/%s",$logo_path,$year,$mon,$day);
  if(!is_dir($logo_path)){
   $res=mkdir($logo_path,0777,true);
  }
  //图片上传
  //foreach($photos as $key => $photo ){
  $photo = $_FILES[&#39;photos&#39;];
  $name = $key_name;
 
  $file_id = Input::file($name);
  if(!empty($file_id) && $file_id -> isValid()){
   $entension = $file_id -> getClientOriginalExtension();
   if($pre_name == &#39;baby&#39;){
    $new_name = $pre_name . "_" . intval($salt) ."_" .time() . "_" . salt_rand(2,2);
   }else {
    $new_name = $pre_name . "_" . intval($salt) ."_" . salt_rand(2,2);
   }
   $path_id = $file_id -> move($logo_path,$new_name."_b.".$entension);
   if(!empty($path_id)){
    $path_name = $path_id->getPathName();
    $image_size=getimagesize($path_name);
 $weight=$image_size["0"];////获取图片的宽 
 
$height=$image_size["1"];///获取图片的高
if($pre_name == "baby" || $pre_name == "video") {   
 
   $photo_info[&#39;url&#39;] = $path_name;  
 
   $photo_info[&#39;width&#39;] = $weight;
  $photo_info[&#39;height&#39;] = $height;
 $result_arr[] = $photo_info;
 }else{
 $result_arr[] = $path_name;
 } 
    //处理图片
if($make == 1){
 $img = Image::make($path_name)->resize(200, $height*200/$weight);
$img->save($logo_path ."/".$new_name."_s.".$entension);
 //dd($img);
 // return $img->response(&#39;jpg&#39;);
    }
   }
if(empty($result_arr)){
 $response[&#39;result_code&#39;] = -1006;
 $response[&#39;result_msg&#39;] = $App_Error_Conf[-1006];
  return response($response);
   }
 if($encode == 1){
    $result_arr = json_encode($result_arr);
   }
  }
  return $result_arr;
 }
 }

Dieses Codeformat ist wirklich nervig, also habe ich es einfach geklärt.

Auf diese Weise haben wir mit dem Hochladen von Bildern und den Schnittstellenfunktionen des Miniprogramms begonnen.

Das Obige ist der Inhalt des Tutorials zum Hochladen von Bildern + Serverempfang für die WeChat-Applet-Entwicklung. Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website (www.php.cn)!


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