微信公眾平台php介面
① 怎樣用php開發微信的公眾平台介面
<table border="1" align="center" cellpadding="1" cellspacing="1"> <tr> <th height="41" colspan="9" scope="col"><h1>九九乘法表</h1></th> </tr><?phpfor($i=1;$i<10;$i++){ echo "<tr>"; for($j=1;$j<=$i;$j++) { echo '<td>'.$j.'×'.$i.'='.$i*$j.'</td>'; }}echo '</table>';?>大概是這樣的,建議樓主詳細去後盾人自學,對你學習PHP很有幫助,最近還有實訓班活動
② 微信公眾平台消息介面里,如何用php獲取用戶頭像
現在大概是三種方法:
發給用戶信息,讓用戶自己填寫名字和頭像。
利用oauth2.0獲得
利用curl函數模擬公眾號 登陸獲得
③ 如何為微信公眾號配置介面
請務必認真閱讀以下2步內容,才能更有效的完成配置工作,有疑問的請聯系QQ:863786488提問。
第一步、在微幫手綁定你的微信公眾號。
1、注冊並登錄微幫手介面平台
2、添加公眾號
→
功能管理
→
勾選要開啟的功能
第二步、到微信公眾平台設置介面。
1、登錄
微信公眾平台(http://mp.weixin.qq.com/),進行身份認證,填寫信息,提交身份證。
認證後,點擊高級功能
→
進入開發模式
2、點擊"成為開發者"按鈕
3、填寫介面配置信息
比如你微幫手平台上的地址是http://www.weixinbs.com/index.php/api/demo
那麼URL就是http://www.weixinbs.com/INDEX.PHP/api/demo
Token填寫
4、確認開啟
5、在手機上用微信給你的公眾號輸入"幫助",測試你的介面是否配置正常!
④ 我想學php微信公眾號介面開發,學了php基礎後,該幹嘛 了求指教,謝謝
多做項目,學習裡面的邏輯關系,然後最好有函數基礎,這樣寫微信公眾號比較好寫一點;
公眾號用auth2.0授權方法;
其餘的都是POST請求和GET請求;
了解這些基本就能做微信公眾號開發了;
還有了解常用的格式XML,JSON等;
⑤ php網站代碼怎麼接入微信公眾平台
你需要有一個伺服器或空間之類的,而且還得有個域名,再獲取微信公眾平台的AppID和AppSecret再通過你的PHP程序處理成驗證URL與TOKEN,再將你的URL與TOKEN輸入到微信公眾平台驗證,成功後就說明接入OK了,是不是很簡單!
⑥ 求微信公眾號介面 給客戶發送信息的 PHP代碼
你好,可以用客服消息介面或模板消息介面實現。但是需要認證公眾號才能有許可權。
認證服務號可以發送客服介面消息[需要對應openid24小時內有互動]和模板消息,訂閱號則沒有模板消息許可權。
發送文字消息示例:
$postdata='{"touser":"o5BkRs_vRwfPqAb1ceXHfJDzmQ5o","msgtype":"text","text":{"content":"HelloWorld"}}';
$opts=array(
'http'=>array(
'method'=>'POST',
'Content-Length'=>strlen($postdata),
'Host'=>'api.weixin.qq.com',
'Content-Type'=>'application/json',
'content'=>$postdata
)
);
$context=stream_context_create($opts);
$result=file_get_contents('https://api.weixin.qq.com/cgi-bin/message/custom/send?access_token=你的access_token',true,$context);
echo$result;
⑦ 關於微信公眾平台介面的問題,php的,jsp的都來看一下
微信內容認的標簽:a標簽,p標簽(僅蘋果版支持)
⑧ php系統怎麼和微信公眾平台對接的
define("TOKEN", "wapwuw"); 這里的wapwuw就是你的對接字元,可以隨意更改,但伺服器與微信開發里的要一致。 簡單點說,如果你的介面文件為index.php 那你在index.php里要設置一個跟你微信公眾平台開發模式下的Token(令牌)要一樣。
⑨ 微信公眾平台如何通過php代碼給會員發送被動響應消息
明確在哪接收消息
從微信公眾平台介面消息指南中可以了解到,當用戶向公眾帳號發消息時,微信伺服器會將消息通過POST方式提交給我們在介面配置信息中填寫的URL,而我們就需要在URL所指向的請求處理類CoreServlet的doPost方法中接收消息、處理消息和響應消息。
接收、處理、響應消息
下面先來看我已經寫好的CoreServlet的完整代碼:
package org.liufeng.course.servlet;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.liufeng.course.service.CoreService;
import org.liufeng.course.util.SignUtil;
/**
* 核心請求處理類
*
* @author liufeng
* @date 2013-05-18
*/
public class CoreServlet extends HttpServlet {
private static final long serialVersionUID = 4440739483644821986L;
/**
* 確認請求來自微信伺服器
*/
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// 微信加密簽名
String signature = request.getParameter("signature");
// 時間戳
String timestamp = request.getParameter("timestamp");
// 隨機數
String nonce = request.getParameter("nonce");
// 隨機字元串
String echostr = request.getParameter("echostr");
PrintWriter out = response.getWriter();
// 通過檢驗signature對請求進行校驗,若校驗成功則原樣返回echostr,表示接入成功,否則接入失敗
if (SignUtil.checkSignature(signature, timestamp, nonce)) {
out.print(echostr);
}
out.close();
out = null;
}
/**
* 處理微信伺服器發來的消息
*/
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// 將請求、響應的編碼均設置為UTF-8(防止中文亂碼)
request.setCharacterEncoding("UTF-8");
response.setCharacterEncoding("UTF-8");
// 調用核心業務類接收消息、處理消息
String respMessage = CoreService.processRequest(request);
// 響應消息
PrintWriter out = response.getWriter();
out.print(respMessage);
out.close();
}
}
代碼說明:
1)第51行代碼:微信伺服器POST消息時用的是UTF-8編碼,在接收時也要用同樣的編碼,否則中文會亂碼;
2)第52行代碼:在響應消息(回復消息給用戶)時,也將編碼方式設置為UTF-8,原理同上;
3)第54行代碼:調用CoreService類的processRequest方法接收、處理消息,並得到處理結果;
4)第57~59行:調用response.getWriter().write()方法將消息的處理結果返回給用戶
從doPost方法的實現可以看到,它是通過調用CoreService類的processRequest方法接收、處理消息的,這樣做的目的是為了解耦,即業務相關的操作都不在Servlet里處理,而是完全交由業務核心類CoreService去做。下面來看CoreService類的代碼實現:
package org.liufeng.course.service;
import java.util.Date;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import org.liufeng.course.message.resp.TextMessage;
import org.liufeng.course.util.MessageUtil;
/**
* 核心服務類
*
* @author liufeng
* @date 2013-05-20
*/
public class CoreService {
/**
* 處理微信發來的請求
*
* @param request
* @return
*/
public static String processRequest(HttpServletRequest request) {
String respMessage = null;
try {
// 默認返回的文本消息內容
String respContent = "請求處理異常,請稍候嘗試!";
// xml請求解析
Map<String, String> requestMap = MessageUtil.parseXml(request);
// 發送方帳號(open_id)
String fromUserName = requestMap.get("FromUserName");
// 公眾帳號
String toUserName = requestMap.get("ToUserName");
// 消息類型
String msgType = requestMap.get("MsgType");
// 回復文本消息
TextMessage textMessage = new TextMessage();
textMessage.setToUserName(fromUserName);
textMessage.setFromUserName(toUserName);
textMessage.setCreateTime(new Date().getTime());
textMessage.setMsgType(MessageUtil.RESP_MESSAGE_TYPE_TEXT);
textMessage.setFuncFlag(0);
// 文本消息
if (msgType.equals(MessageUtil.REQ_MESSAGE_TYPE_TEXT)) {
respContent = "您發送的是文本消息!";
}
// 圖片消息
else if (msgType.equals(MessageUtil.REQ_MESSAGE_TYPE_IMAGE)) {
respContent = "您發送的是圖片消息!";
}
// 地理位置消息
else if (msgType.equals(MessageUtil.REQ_MESSAGE_TYPE_LOCATION)) {
respContent = "您發送的是地理位置消息!";
}
// 鏈接消息
else if (msgType.equals(MessageUtil.REQ_MESSAGE_TYPE_LINK)) {
respContent = "您發送的是鏈接消息!";
}
// 音頻消息
else if (msgType.equals(MessageUtil.REQ_MESSAGE_TYPE_VOICE)) {
respContent = "您發送的是音頻消息!";
}
// 事件推送
else if (msgType.equals(MessageUtil.REQ_MESSAGE_TYPE_EVENT)) {
// 事件類型
String eventType = requestMap.get("Event");
// 訂閱
if (eventType.equals(MessageUtil.EVENT_TYPE_SUBSCRIBE)) {
respContent = "謝謝您的關注!";
}
// 取消訂閱
else if (eventType.equals(MessageUtil.EVENT_TYPE_UNSUBSCRIBE)) {
// TODO 取消訂閱後用戶再收不到公眾號發送的消息,因此不需要回復消息
}
// 自定義菜單點擊事件
else if (eventType.equals(MessageUtil.EVENT_TYPE_CLICK)) {
// TODO 自定義菜單權沒有開放,暫不處理該類消息
}
}
textMessage.setContent(respContent);
respMessage = MessageUtil.textMessageToXml(textMessage);
} catch (Exception e) {
e.printStackTrace();
}
return respMessage;
}
}
代碼說明:
1)第29行:調用消息工具類MessageUtil解析微信發來的xml格式的消息,解析的結果放在HashMap里;
2)32~36行:從HashMap中取出消息中的欄位;
3)39-44、84行:組裝要返回的文本消息對象;
4)47~82行:演示了如何接收微信發送的各類型的消息,根據MsgType判斷屬於哪種類型的消息;
5)85行:調用消息工具類MessageUtil將要返回的文本消息對象TextMessage轉化成xml格式的字元串;
關於事件推送(關注、取消關注、菜單點擊)
對於消息類型的判斷,像文本消息、圖片消息、地理位置消息、鏈接消息和語音消息都比較好理解,有很多剛接觸的朋友搞不懂事件推送消息有什麼用,或者不清楚該如何判斷用戶關注的消息。那我們就專門來看下事件推送,下圖是官方消息介面文檔中關於事件推送的說明: