国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

ホームページ WeChat アプレット WeChatの開発 WeChat二次開発テキストメッセージのリクエストと送信

WeChat二次開発テキストメッセージのリクエストと送信

May 10, 2017 am 09:25 AM
java 微信

この記事では主に Java WeChat 二次開発の第 2 部、Java WeChat テキスト メッセージ インターフェイスのリクエストと送信機能を詳しく紹介します。興味のある友人は參考にしてください。

第 2 部、WeChat テキスト メッセージの作成。インターフェイスのリクエストと送信の具體的な內(nèi)容は次のとおりです

ライブラリをインポートする必要があります: dom4j-1.6.1.jar、xstream-1.3.1.jar

ステップ 1:新しいパッケージ com.wtz.message を作成します.response 、新しいクラス BaseMessage.java

package com.wtz.message.response;

/**
 * @author wangtianze QQ:864620012
 * @date 2017年4月19日 下午3:12:40
 * <p>version:1.0</p>
 * <p>description:基礎消息類</p>
 */
public class BaseMessage {
 //接收方
 private String ToUserName;
 //發(fā)送方
 private String FromUserName;
 //消息的創(chuàng)建時間
 private long CreateTime;
 //消息類型
 private String MsgType;
 
 public String getToUserName() {
 return ToUserName;
 }
 public void setToUserName(String toUserName) {
 ToUserName = toUserName;
 }
 public String getFromUserName() {
 return FromUserName;
 }
 public void setFromUserName(String fromUserName) {
 FromUserName = fromUserName;
 }
 public long getCreateTime() {
 return CreateTime;
 }
 public void setCreateTime(long createTime) {
 CreateTime = createTime;
 }
 public String getMsgType() {
 return MsgType;
 }
 public void setMsgType(String msgType) {
 MsgType = msgType;
 }
}
を作成します

2 番目のステップ: パッケージ com.wtz.message.response を見つけます、新しいクラス TextMessage.java

package com.wtz.message.response;

/**
 *  @author wangtianze QQ:864620012
 * @date 2017年4月19日 下午3:22:33
 * <p>version:1.0</p>
 *  <p>description:文本消息類</p>
 */
public class TextMessage extends BaseMessage{
 //消息內(nèi)容
 private String Content;
 
 public String getContent() {
  return Content;
 }
 public void setContent(String content) {
  Content = content;
 }
}

を作成します 3 番目のステップ: パッケージ com を見つけます.wtz.util を作成し、新しいクラス MessageUtil を作成します。java

package com.wtz.util;

import java.io.IOException;
import java.io.InputStream;
import java.io.Writer;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import javax.servlet.http.HttpServletRequest;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;

import com.thoughtworks.xstream.XStream;
import com.thoughtworks.xstream.core.util.QuickWriter;
import com.thoughtworks.xstream.io.HierarchicalStreamWriter;
import com.thoughtworks.xstream.io.xml.PrettyPrintWriter;
import com.thoughtworks.xstream.io.xml.XppDriver;
import com.wtz.message.response.TextMessage;

/**
 *  @author wangtianze QQ:864620012
 * @date 2017年4月19日 下午3:29:58
 * <p>version:1.0</p>
 *  <p>description:消息處理工具類</p>
 */
public class MessageUtil {
 //定義了消息類型(常量:文本類型)
 public static final String RESP_MESSAGE_TYPE_TEXT = "text";
 
 //從流中解析出每個節(jié)點的內(nèi)容
 public static Map<String,String> parseXml(HttpServletRequest request) throws IOException{
  Map<String,String> map = new HashMap<String,String>();
  
  //從輸入流中獲取流對象
  InputStream in = request.getInputStream();
  
  //構建SAX閱讀器對象
  SAXReader reader = new SAXReader();
  try {
   //從流中獲得文檔對象
   Document doc = reader.read(in);
   
   //獲得根節(jié)點
   Element root = doc.getRootElement();
   
   //獲取根節(jié)點下的所有子節(jié)點
   List<Element> children = root.elements();
   
   for(Element e:children){
    //遍歷每一個節(jié)點,并按照節(jié)點名--節(jié)點值放入map中
    map.put(e.getName(), e.getText());
    System.out.println("用戶發(fā)送的消息XML解析為:" + e.getName() + e.getText());
   }
   
   //關閉流
   in.close();
   in = null;
  } catch (DocumentException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
  
  return map;
 }
 
 /**
  * 用于擴展節(jié)點數(shù)據(jù)按照<ToUserName><![CDATA[toUser]]></ToUserName>,中間加了CDATA段
  */
 private static XStream xstream = new XStream(new XppDriver(){
  public HierarchicalStreamWriter createWriter(Writer out){
   return new PrettyPrintWriter(out){
    boolean cdata = true;
    public void startNode(String name,Class clazz){
     super.startNode(name,clazz);
    }
    
    protected void writeText(QuickWriter writer,String text){
     if(cdata){
      writer.write("<![CDATA[");
      writer.write(text);
      writer.write("]]>");
     }else{
      writer.write(text);
     }
    }
   };
  }
 });
 
 /**
  * 將文本消息轉(zhuǎn)換成XML格式
  */
 public static String messageToXml(TextMessage textMessage){
  xstream.alias("xml",textMessage.getClass());
  String xml = xstream.toXML(textMessage);
  System.out.println("響應所轉(zhuǎn)換的XML:"+xml);
  return xml;
 }
}

ステップ 4:パッケージ com.wtz.service を見つけて、新しいクラス ProcessService.java

package com.wtz.util;

import java.io.IOException;
import java.util.Date;
import java.util.Map;

import javax.servlet.http.HttpServletRequest;

import com.wtz.message.response.TextMessage;

/**
 *  @author wangtianze QQ:864620012
 * @date 2017年4月19日 下午8:04:14
 * <p>version:1.0</p>
 *  <p>description:核心服務類</p>
 */
public class ProcessService {
 public static String dealRequest(HttpServletRequest request) throws IOException{
  //響應的XML串
  String respXml = "";
  
  //要響應的文本內(nèi)容
  String respContent = "未知的消息類型";
  Map<String,String> requestMap = MessageUtil.parseXml(request);
  String fromUserName = requestMap.get("FromUserName");
  String toUserName = requestMap.get("ToUserName");
  String MsgType = requestMap.get("MsgType");
  String Content = requestMap.get("Content");
  
  System.out.println("用戶給公眾號發(fā)的消息為:" + Content);
  
  //構建一條文本消息
  TextMessage textMessage = new TextMessage();
  textMessage.setToUserName(fromUserName);
  textMessage.setFromUserName(toUserName);
  textMessage.setCreateTime(new Date().getTime());
  textMessage.setMsgType(MessageUtil.RESP_MESSAGE_TYPE_TEXT);
  
  if(MsgType.equals(MessageUtil.RESP_MESSAGE_TYPE_TEXT)){
   respContent = "王天澤的公眾號收到了您的一條文本消息:" + Content + ",時間戳是:" + (new Date().getTime());
  }
  textMessage.setContent(respContent);
  respXml = MessageUtil.messageToXml(textMessage);
  
  System.out.println("respXml:"+respXml);
  
  return respXml;
 }
}

を作成します。ステップ 5:以下で LoginServlet クラスを見つけます。 com.wtz.service パッケージを作成し、doPost メソッドを書き換えます

package com.wtz.service;

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 com.wtz.util.MessageUtil;
import com.wtz.util.ProcessService;
import com.wtz.util.ValidationUtil;

/**
 *  @author wangtianze QQ:864620012
 * @date 2017年4月17日 下午8:11:32
 * <p>version:1.0</p>
 *  <p>description:微信請求驗證類</p>
 */
public class LoginServlet extends HttpServlet {

 @Override
 protected void doGet(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {
  System.out.println("get請求。。。。。。");
  
  //1.獲得微信簽名的加密字符串
  String signature = request.getParameter("signature");
  
  //2.獲得時間戳信息
  String timestamp = request.getParameter("timestamp");
   
  //3.獲得隨機數(shù)
  String nonce = request.getParameter("nonce");
  
  //4.獲得隨機字符串
  String echostr = request.getParameter("echostr");
  
  System.out.println("獲得微信簽名的加密字符串:"+signature);
  System.out.println("獲得時間戳信息:"+timestamp);
  System.out.println("獲得隨機數(shù):"+nonce);
  System.out.println("獲得隨機字符串:"+echostr);
  
  PrintWriter out = response.getWriter();
  
  //驗證請求確認成功原樣返回echostr參數(shù)內(nèi)容,則接入生效,成為開發(fā)者成功,否則失敗
  if(ValidationUtil.checkSignature(signature, timestamp, nonce)){
   out.print(echostr);
  }
  
  out.close();
  out = null;
 }

 /**
  * 接受微信服務器發(fā)過來的XML數(shù)據(jù)包(通過post請求發(fā)送過來的)
  */
 @Override
 protected void doPost(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {
  
  request.setCharacterEncoding("utf-8");
  response.setCharacterEncoding("utf-8");
  
  //獲取微信加密的簽名字符串
  String signature = request.getParameter("signature");
  
  //獲取時間戳
  String timestamp = request.getParameter("timestamp");
  
  //獲取隨機數(shù)
  String nonce = request.getParameter("nonce");
  
  PrintWriter out = response.getWriter();
  
  if(ValidationUtil.checkSignature(signature,timestamp,nonce)){
   String respXml = "";
   try {
    respXml = ProcessService.dealRequest(request);
   } catch (Exception e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }
   out.print(respXml);
  }
  out.close();
  out = null;
 }
}

WeChat テキスト メッセージ インターフェイスのリクエストと送信を完了します。

【関連推奨事項】

1. WeChatパブリックアカウントプラットフォームのソースコードダウンロード

2. WeChat投票ソースコード

以上がWeChat二次開発テキストメッセージのリクエストと送信の詳細內(nèi)容です。詳細については、PHP 中國語 Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當する法的責任を負いません。盜作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード寫真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

寫真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中國語版

SublimeText3 中國語版

中國語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統(tǒng)合開発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

JDBCを使用してJavaのトランザクションを処理する方法は? JDBCを使用してJavaのトランザクションを処理する方法は? Aug 02, 2025 pm 12:29 PM

JDBCトランザクションを正しく処理するには、最初に自動コミットモードをオフにし、次に複數(shù)の操作を?qū)g行し、結果に応じて最終的にコミットまたはロールバックする必要があります。 1。CONN.SETAUTOCOMMIT(FALSE)を呼び出して、トランザクションを開始します。 2。挿入や更新など、複數(shù)のSQL操作を?qū)g行します。 3。すべての操作が成功した場合はconn.commit()を呼び出し、データの一貫性を確保するために例外が発生した場合はconn.rollback()を呼び出します。同時に、リソースを使用してリソースを管理し、例外を適切に処理し、接続を密接に接続するために、接続の漏れを避けるために使用する必要があります。さらに、接続プールを使用してセーブポイントを設定して部分的なロールバックを達成し、パフォーマンスを改善するためにトランザクションを可能な限り短く保つことをお勧めします。

Javaでカレンダーを操作する方法は? Javaでカレンダーを操作する方法は? Aug 02, 2025 am 02:38 AM

Java.Timeパッケージのクラスを使用して、古い日付とカレンダーのクラスを置き換えます。 2。LocalDate、LocalDateTime、LocalTimeを通じて現(xiàn)在の日付と時刻を取得します。 3。of()メソッドを使用して特定の日付と時刻を作成します。 4.プラス/マイナスメソッドを使用して、時間を不正に増加させて短縮します。 5. ZonedDateTimeとZoneIDを使用して、タイムゾーンを処理します。 6。DateTimeFormatterを介したフォーマットおよび解析の文字列。 7.インスタントを使用して、必要に応じて古い日付型と互換性があります。現(xiàn)代のJavaでの日付処理は、java.timeapiを使用することを優(yōu)先する必要があります。

Javaフレームワークの比較:Spring Boot vs Quarkus vs Micronaut Javaフレームワークの比較:Spring Boot vs Quarkus vs Micronaut Aug 04, 2025 pm 12:48 PM

Pre-formanceTartuptimeMemoryusage、quarkusandmicronautleadduetocopile-timeprocessingingandgraalvsupport、withquarkusoftentylightbetterine serverlessシナリオ。

Garbage CollectionはJavaでどのように機能しますか? Garbage CollectionはJavaでどのように機能しますか? Aug 02, 2025 pm 01:55 PM

JavaのGarbage Collection(GC)は、メモリを自動的に管理するメカニズムであり、到達不可能なオブジェクトを取り戻すことでメモリ漏れのリスクを軽減します。 1.GCルートオブジェクトからのオブジェクトのアクセシビリティ(スタック変數(shù)、アクティブスレッド、靜的フィールドなど)、および到達不可能なオブジェクトはゴミとしてマークされています。 2。マーククリアリングアルゴリズムに基づいて、すべての到達可能なオブジェクトをマークし、マークのないオブジェクトをクリアします。 3.世代の収集戦略を採用する:新世代(Eden、S0、S1)は頻繁にMinorGCを?qū)g行します。高齢者のパフォーマンスは少なくなりますが、MajorGCを?qū)g行するのに時間がかかります。 Metaspaceはクラスメタデータを保存します。 4。JVMはさまざまなGCデバイスを提供します。SerialGCは小さなアプリケーションに適しています。 ParallelGCはスループットを改善します。 CMSが減少します

説明された延期聲明の例で進みます 説明された延期聲明の例で進みます Aug 02, 2025 am 06:26 AM

Deferは、クリーニングリソースなど、関數(shù)が戻る前に指定された操作を?qū)g行するために使用されます。パラメーターは、延期時にすぐに評価され、関數(shù)は最後のファーストアウト(LIFO)の順に実行されます。 1.複數(shù)の債務は、宣言の逆の順序で実行されます。 2.ファイルの閉鎖などの安全なクリーニングに一般的に使用されます。 3。指定された返品値を変更できます。 4.回復に適したパニックが発生した場合でも実行されます。 5。リソースの漏れを防ぐために、ループで延期の亂用を避けます。正しい使用により、コードのセキュリティと読みやすさが向上します。

Javaビルドツールの比較:Maven vs. Gradle Javaビルドツールの比較:Maven vs. Gradle Aug 03, 2025 pm 01:36 PM

gradleisthebetterchoiceformostnewprojectoitssuperorfficability、performance、andmoderntoolingsupport.1.gradle’sgroovy/kotlindslismoreconciseandexpressiveethanmaven’sverboseml.2.gradleorformsmavenbenbumebutedwitedwitedwitedspedexは

Javaでオブザーバーパターンを使用する方法は? Javaでオブザーバーパターンを使用する方法は? Aug 02, 2025 am 11:52 AM

この質(zhì)問に対する明確な答えは、カスタムオブザーバーインターフェイスを使用してオブザーバーパターンを?qū)g裝するための推奨事項です。 1. Javaは観察可能なオブザーバーを提供していますが、前者はクラスであり、廃止されており、柔軟性がありません。 2。最新の推奨される実踐は、機能的なオブザーバーインターフェイスを定義することであり、被験者はオブザーバーリストを維持し、狀態(tài)が変更されたときにすべてのオブザーバーに通知することです。 3.ラムダ式と組み合わせて使用して、コードのシンプルさと保守性を向上させることができます。 4。GUIまたはJavabeanシナリオの場合、PropertyChangelistenerを使用できます。したがって、新しいプロジェクトはカスタムオブザーバーインターフェイススキームを採用する必要があります。カスタムオブザーバーインターフェイススキームは、タイプセーフでテストしやすく、現(xiàn)代のJavaを?qū)熼Tとしています

Java Concurrencyユーティリティ:ExecutorServiceおよびFork/Join Java Concurrencyユーティリティ:ExecutorServiceおよびFork/Join Aug 03, 2025 am 01:54 AM

ExecutorServiceは、I/O操作やタイミングタスクなどの獨立したタスクの非同期実行に適しています。スレッドプールを使用して並行性を管理し、送信を通じて実行可能または呼び出し可能なタスクを送信し、將來の結果を取得します。固定されていないキューのリスクに注意を払い、スレッドプールを明示的に閉じます。 2.フォーク/Joinフレームワークは、分割と論爭の方法とワークスチールアルゴリズムに基づいた分割および政府CPU集約型タスク用に設計されており、フォークジョインプールによってスケジュールおよび実行された再帰イベタスクまたは再送信によるタスクの再帰的分割を?qū)g現(xiàn)します。大規(guī)模な配列の合計と並べ替えシナリオに適しています。分割のしきい値は、オーバーヘッドを避けるために合理的に設定する必要があります。 3。選択基準:獨立

See all articles