接下來將講後台如何與前台進行數據及圖片之間的交互,相信這一點是很多人所關注的,因為當時我實在團隊中負責後台開發,因此對前端不是特別了解,這裡我會貼出前端開發時的部分程式碼截圖,微信小程式的官方api介紹網址是:
https://mp.weixin.qq.com/debug/wxadoc/dev/api/api -network.html
微信與後台伺服器之間的資料通訊是呼叫wx.request(OBJECT)實現的,官方api介面裡有對此說明,
例如前台向後台發送數據,需要連結伺服器php作用路徑下的特定php文件,並以key-value形式封裝json格式數據,請看以下程式碼:
#url是伺服器的網域名稱及isbn.php在伺服器的位置,這個位置是相對位置,在我上一篇購買的鏡像裡預設php檔案路徑為: /yjdata/www/
,這意味著直接放在這個資料夾下的php只需要在網域後面直接/+*.php即可,如果為了方便管理在這個目錄下建造了一個資料夾則在網域後/資料夾名字/*.php即可。
<?php$result=$_GET["result"];/*获取前端微信小程序扫书的isbn结果*/
/*与第三方接口通信获取书本信息*/
$book_info=file_get_contents("https://api.douban.com/v2/book/isbn/:".$result);$jsondecode = json_decode($book_info,true);/*将获取到的书本信息JSON解码*/$title=$jsondecode["title"];/*将解码后书名赋值给title变量*/$author=$jsondecode["author"];/*将解码后作者赋值给author变量*/$publisher=$jsondecode["publisher"];/*将解码后出版社名赋值给publisher变量*/echo "title=".$title; /*向前端返回书名*/echo "author=".$author; /*向前端返回作者名*/echo "publisher=".$publisher; /*向前端返回出版社名*/?>
具體的註釋都寫得很詳細,向前台返回資料則直接用echo即可,一般開發都要與資料庫打交道,因此,後台程式就需要依據前台傳來的數據對資料庫進行操作,這一部分其實也就是接受前台的數據,執行對應的資料庫操作,這一部分只要是講到php資料庫操作的都會有,這裡我不再進行過多闡述。
<?phpheader('content-type:application/json;charset=utf8');$mysql_server_name="localhost";/*数据库服务器名称*/$mysql_username="root";/*数据库用户名*/$mysql_password="123456";/*数据库用户密码*/$mysql_databasename="zhishu";/*进入数据库后数据库名*/$conn=mysqli_connect($mysql_server_name,$mysql_username,$mysql_password,$mysql_databasename);/*数据库连接语句*/;;$bookname=$_POST["bookname"];/*从小程序前端获取书本名字*/$authorname=$_POST["authorname"];/*从小程序前端获取书本作者名字*/$bookintroduce=$_POST["introduce"];/*从小程序前端获取书本介绍信息*/$bookholder_name=$_POST["openid"];/*从小程序前端获取书本持有人昵称*/$bookclass=$_POST['classification'];;/*从小程序前端获取书本分类*/date_default_timezone_set('PRC'); /*设置默认时区为中国*/$time=(string)date("Y-m-d-h-i",time());/*获取时间*/function Unioname($a) /*将时间格式更改的函数*/{ $a=explode('-',$a); $a=implode('',$a); return $a; }$time=Unioname($time);$allowedExts = array("gif", "jpeg", "jpg", "png"); /*这里的内容同用户注册时代码含义一样,只不过那时是为了存用户头像并修改用户头像名字,这里是存书本图像并修改书本图像的名字*/$temp = explode(".", $_FILES["file"]["name"]);//将图片名字以.分割成两个字符串$extension = end($temp); // 获取图片后缀名if ((($_FILES["file"]["type"] == "image/gif") || ($_FILES["file"]["type"] == "image/jpeg") || ($_FILES["file"]["type"] == "image/jpg") || ($_FILES["file"]["type"] == "image/pjpeg") || ($_FILES["file"]["type"] == "image/x-png") || ($_FILES["file"]["type"] == "image/png")) && ($_FILES["file"]["size"] < 1024000) // 小于 1MB && in_array($extension, $allowedExts)) { if ($_FILES["file"]["error"] > 0) { echo "错误:: " . $_FILES["file"]["error"] . "<br>"; } else { // 判断当期目录下的 upload 目录是否存在该文件 // 如果没有 upload 目录,你需要创建它,upload 目录权限为 777 if (file_exists("bookimage/" . $_FILES["file"]["name"])) { echo $_FILES["file"]["name"] . " 文件已经存在。 "; } else { // 如果 upload 目录不存在该文件则将文件上传到 upload 目录下 move_uploaded_file($_FILES["file"]["tmp_name"], "bookimage/".$_FILES["file"]["name"]); $oldname = "bookimage/" . $_FILES["file"]["name"]; $newname = "bookimage/" . $time .$bookholder_name.".".$extension; rename($oldname, $newname); $sql_num="select * from book"; $reasult=mysqli_query($conn,$sql_num); $reasult_num=mysqli_num_rows($reasult); /*将获取到书本信息插入数据库语句*/ $sql_insert="insert into book (book_id,bookname,authorname,book_intro,bookclass,bookholder_openid,bookpicture_path,is_CunZai,ChengJiao_num) VALUES ($reasult_num+1,'$bookname','$authorname','$bookintroduce','$bookclass','$bookholder_openid','$newname','1',0)";
if( mysqli_query($conn,$sql_insert)) { echo "插入书籍成功!"; } else { echo "插入失败"; } } } }mysqli_close($conn); /*关闭数据库连接*/?>
首先使用$[FILE]全域數組接受文件,其擁有的幾個屬性如下:
$_FILES["file"]["name"] - 上傳檔案的名稱
#$_FILES["file "]["type"] - 上傳檔案的型別
$_FILES["file"]["size"] - 上傳檔案的大小,以位元組計$_FILES["file"]["tmp_name"] - 儲存在伺服器的檔案的暫存副本的名稱
相關推薦:
以上是微信小程式實作與後台PHP交互的詳細內容。更多資訊請關注PHP中文網其他相關文章!