标签: java

Java实现服务器和客户端简单通信

Java中网络编程这一块有封装的类库,使用简单,了解原理可以教容易实现服务器和客户端的简单通信。

在编程之前,首先要需要对TCP/IP协议有一定的了解,需要知道Socket套接字的作用以及用法,这个可以在API文档中去查看。两通讯实体之间通信需要掌握数据的传输方式,这里主要掌握java中IO流的使用。java中IO流都封装好了,有专门的类进行处理。通过编程之后可以知道封装好的IO流使用多么方便。

下面需要从宏观了解什么是输入输出流:
%title插图%num

在程序A中,A接收的数据封装成输入流,A发送的数据封装成输出流。B也一样。

Socket套接字有两个重要的方法:
—– getInputStream():返回socket对象对应的输入流。
—– getOutputStream():返回socket对象对应的输出流。

了解完以上的知识,可以着手编程了。

服务器程序:

import java.net.*;
import java.io.*;
public class CS_Server
{
public static void main(String[] args) throws Exception
{
ServerSocket ss = new ServerSocket(38380);//是一个能够接受其他通信实体请求的类
System.out.println(“服务器正在等待客户端的连接请求—-“);
//用一个while循环可以同时响应多个客户端的请求
while(true){
Socket sk= ss.accept();//服务器监听对应端口的输入
ServerThread st = new ServerThread(sk);//创建一个线程,用线程创建一个套接字
st.start();
}
}
}

//服务器线程类
class ServerThread extends Thread
{
Socket sk;
public ServerThread(Socket sk){
this.sk= sk;
}
public void run() {
BufferedReader br=null;
try{
br = new BufferedReader(new InputStreamReader(sk.getInputStream()));
String line = br.readLine();
System.out.println(“来自客户端的数据:”+line);
br.close();
sk.close();
}
catch(IOException e){
e.printStackTrace();
}
}
}

客户端程序:

import java.net.*;
import java.io.*;
import java.util.Scanner;
public class CS_Client
{
public static void main(String[] args)
{
try{
Socket sk =new Socket(“127.0.0.1”,38380);
System.out.println(“客户端已经开启—-“);
PrintStream ps = new PrintStream(sk.getOutputStream());//将客户端套接字的输出流用printStream包装起来,类似于C语言中的fprintf类型转换
System.out.print(“请输入需要发送到服务器的内容:”);
Scanner sn = new Scanner(System.in);
String str = sn.nextLine();
ps.println(str);//把控制台输入的内容送入被printstream类包装的输出流里面
ps.close();//关闭输出流包装
sk.close();//关闭socket套接字,已经传完数据,才能关闭
}
catch(Exception e){
e.printStackTrace();
}
}
}

先开启服务器程序,服务器等待客户端的连接请求。

%title插图%num

后记:这是java讲到网络编程必须要讲的例子,所以必须要懂,不能做到一知半解。只翻阅文档资料独立将程序实现,其实里面涵盖了很多知识点,这是一个重要的例题。

java 编写简易的http服务器

java 编写简易的http服务器
想要写一个http服务器,首先得了解http协议。这里仅介绍一下相关的知识。

1、http协议
HTTP请求报文
在请求中,HTTP报文由方法、URI、HTTP版本、HTTP首部字段等部分构成。其中方法、URI、HTTP版本作为首行,然后每个HTTP首部字段为一行,以上内容简称为请求头,如下请求头:

GET /favicon.ico HTTP/1.1 //首行,GET为请求方法,favicon.ico为url链接,1.1版本号
Host: 172.30.67.185:8080 //以下为首部字段行
Connection: keep-alive
Accept: image/webp,image/apng,image/*,*/*;q=0.8
Accept-Language: zh-CN,zh;q=0.9,en;q=0.8
注:请求报文一般由浏览器(客户端)向服务器发送

HTTP响应报文
在响应中,HTTP报文由HTTP版本、状态码、HTTP首部字段3部分构成,其中HTTP版本、状态码作为首行,然后每个HTTP首部字段为一行,以上内容简称为响应头,如下响应头:

HTTP/1.1 200 OK //首行,1.1为版本号,200为状态码。以下行为首行字段
Content-Type:text/html;charset=utf-8

//空一行后,响应客户端的内容,后面会讲
注:请求报文一般由服务器向浏览器(客户端)发送

2、简单的http服务器
服务器启动程序
首先,编写一个服务器启动程序,我们监听了8080端口,然后得到socket对象,接着new SocketServer(s),然后启动线程。线程池简单看作启动线程的工具就行了(需要深入了解线程池的自行百度)。

public static void main(String[] args) {
ServerSocket server=null;
//线程池,简单来说,就是把线程start()改成ex.execute(),然后可以提高服务器性能
ExecutorService ex=Executors.newFixedThreadPool(20);
try {
//建立服务器监听端口
server=new ServerSocket(8080);
while(true) {
Socket s=server.accept();
//然后把接收到socket传给SocketServer并执行该线程
ex.execute(new SocketServer(s));
}
} catch (IOException e) {
e.printStackTrace();
}
}
接着,因为我们的SocketServer需要做的是做一个http服务器,所以重点来了!怎么接受浏览器(客户端)传来的请求呢?然后又怎么给浏览器(客户端)响应内容呢?

http服务器类
因为浏览器(客户端)的请求方法有GET、POST等,在这里,先写一个响应GET的请求。

思路:

1、打开socket对象的输入流,接收浏览器(客户端)的请求头

2、分析字段内容,判断请求方法、链接

3、打开socket对象的输出流,在输出流里写入响应头

4、空一行,写入响应内容。

import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.net.Socket;

public class SocketServer implements Runnable{
Socket s;
//构造方法
public SocketServer(Socket s) {
this.s=s;
}
//线程
public void run(){
//输入输出流
OutputStream os=null;
InputStream in=null;
try
{ //打开socket输入流,并转为BufferedReader流
in=s.getInputStream();
BufferedReader br=new BufferedReader(new InputStreamReader(in));

//接收*行,得到请求路径
String requestHeader;
requestHeader=br.readLine();
int begin = requestHeader.indexOf(“/”)+1;
int end = requestHeader.indexOf(“HTTP/”);
String url=”E:\\sublime文件\\Html文件\\第二天案例\\”;
url=url+requestHeader.substring(begin, end);

//打开socket对象的输出流,写入响应头
os = s.getOutputStream();
os.write(“HTTP/1.1 200 OK\r\n”.getBytes());
os.write(“Content-Type:text/html;charset=utf-8\r\n”.getBytes());
os.write(“\r\n”.getBytes());

//空一行,写入响应内容。
File f=new File(url);
if(f.exists()) //判断请求的文件是否存在
{
FileInputStream fin=new FileInputStream(f);
byte []b=new byte[1024];
int len;
while((len=fin.read(b))!=-1)
{
os.write(b,0,len);
}
}
os.flush();
//如果os流没有关闭的话,浏览器会以为内容还没传输完成,将一直显示不了内容
os.close();

}

}
实现过程非常简单,简单到没有判断浏览器(客户端)的请求方法,直接返回了一个请求路径的文件。

Java版服务器开发总结

今天打算对之前进行多年的Java版服务器端开发进行下技术总结,以供大家参考。

个人对服务器开发基础框架平台有以下几点总结(会随时更新):

1、 网络设计(BIO(java.net包)和NIO(java.nio.channels包)两种方式,参考MINA(C/S), JETTY(B/S)、jsockets和jniosocket等开源项目)(参考资料O’reilly系列网络编程)

2、 传输协议设计(http、https、ftp、smtp等协议和自定义传输协议,基于TCP/IP协议之上)

3、 I/O处理设计(字节流(java.io包)和字符流到Buffer(java.nio包)缓冲区,*后把可以扩展到stream object 转换成POJO,将POJO转换成stream object的范围)(参考O’reilly系列的IO和NIO两本书籍)

4、 可以扩展的XML设计(可以跟其它语言(C++等)开发的系统进行交互请求信息,也是一种很重要的手段,包括解析(JDOM、DOM、SAX、DOM4j等)、生成、语言格式)

5、 管理设计(JMX(参考资料O’reilly系列JMX书籍。javax.management包),JFOXMX、MX4J开源项目)

6、 消息设计(JMS(参考资料O’reilly系列JMS书籍),OPENJMS开源项目)

7、 安全设计(访问控制器、数据加密、数据传输保护和授权(javax.crypto包)参考资料 O’reilly系列java安全书籍、传输加密(javax.net包)等)

8、 缓存设计(JCS(内存缓冲、索引式硬盘缓冲、并行式的分布缓冲和Client/Server式的缓冲)、CACHE4J、EOCACHE等)

9、 多线程池设计(concurrent开源项目,对应java.util.concurrent包)

10、事务处理(包括分布式事务处理)设计(暂缺,可能包含在15和12中==)

11、资源池(数据库连接池、socket连接池、线程池等)、对象池等开销大的资源设计 (可以参考比较优秀的开源项目中设计,可以完善自己的设计思想)

12、数据持久化设计(JDBC、Mybatis、JDO、HIBERNATE、Ibatis等开源项目)

13、WEB框架设计(基础框架SERVLET、SOAP技术。STRUTS、WEBWork、FLEX、WPF、JSF、AJAX、TAPESTRY等开源项目)

14、处理机制的异步设计(责任链设计、流水线设计等)

15、扩展到分布式设计(RMI(参考资料O’reilly系列RMI书籍java.rmi包)、JTA等)

16、扩展到命名空间设计(JNDI(参考资料The JNDI Tutorialjavax.naming包))

17、对象重用设计(这是在代码中要注意的,个人根据经验分析,需要每次创建的对象是请求对象和结果对象,中间过程的所需要的功能对象一般都可以做成重用的方式)

18、JVM的参数优化(类加载技术(包含热部署)属于外部部署,ANT开源项目,Maven)

19、服务器部署的目录结构:BIN、CONF、LIB、LOG目录等。

20、业务逻辑处理设计(根据实际情况来进行,SPRING、EJB、JDON等),严格的来说是另一个范畴。

21、组件设计(属于一些特定领域应用,例如JYTHON、JAVACC、HSQLDB、QUARTZ等开源项目)

22、通过在实际的使用过程中积累经验(解决使用中出现的问题)。

个人认为多核CPU的出现,今后的会发展成并行处理的设计方式和分布式等多个技术发展方面。目前才认识到大学里的基础知识给服务器开发(应该是很多方面)提供了很多基础设计的思想。

9和11可以合并。

10和12本人感觉有点像是业务逻辑处理的数据层面的东西,但还不能确定。

18和19可以合并成一部分,因为都是属于部署方面的。

主要相关技术归类:

%title插图%num

本地时间(北京时间)和“GMT+8”时区时间的区别?

获取本地时间:

Java代码   收藏代码
  1. String time1 = new SimpleDateFormat(“hh:mm:ss”).format(new Date());

获取时区“GMT+8”的时间:

Java代码   收藏代码
  1. String time2 = cal.get(Calendar.HOUR_OF_DAY) + “:” + Calendar.MINUTE + “:” + Calendar.SECOND;

如果“GMT+8”就是北京时间,为什么time1和time2又不相等呢?

下面附上测试代码和测试结果:

Java代码   收藏代码
  1. Calendar cal = new GregorianCalendar(TimeZone.getTimeZone(“GMT+8”));
  2. String time1 = new SimpleDateFormat(“hh:mm:ss”).format(new Date());
  3. String time2 = cal.get(Calendar.HOUR_OF_DAY) + “:” + Calendar.MINUTE + “:” + Calendar.SECOND;
  4. System.out.println(“time1=” + time1);
  5. System.out.println(“time2=” + time2);

 

Java代码   收藏代码
  1. time1=10:54:55
  2. time2=10:12:13

今天查明原因了,上面代码第三行有错误,应该是:

Java代码   收藏代码
  1. String time2 = cal.get(Calendar.HOUR_OF_DAY) + “:” + cal.get(Calendar.MINUTE) + “:” + cal.get(Calendar.SECOND);

另外,要求已知时区的时间,应该像下面这样:

Java代码   收藏代码
  1. public static String getLocalDatetimeString(String local) {
  2.     Calendar cal = new GregorianCalendar(TimeZone.getTimeZone(local));
  3.     cal.setTimeInMillis(Calendar.getInstance().getTimeInMillis());
  4.     String date = cal.get(Calendar.YEAR) + “-“ + (cal.get(Calendar.MONTH) + 1) + “-“ + cal.get(Calendar.DAY_OF_MONTH);
  5.     String time = cal.get(Calendar.HOUR_OF_DAY) + “:” + cal.get(Calendar.MINUTE) + “:” + cal.get(Calendar.SECOND);
  6.     return date + ” “ + time;
  7. }

这样调用:

Java代码   收藏代码
  1. getLocalDatetimeString(“GMT+8”);

Java:复制一个目录下的所有文件到另外一个目录

     首先说说我的思路, 要复制一个目录下的所有文件到另外的一个目录下,我们不知道目录下的结构是怎么样的,也不知道目录有多少层,文件有多少个,这样我们会想用循环,for! 但是我们不知道有多少层,所以循环不能够满足我们的需求! 学过递归的人,都知道这个用递归的思想可以很好解决这个问题的。

       递归这里我就不说是什么东西了,这个自己可以百度,谷歌!

      

     现在说说我的实现, 因为目录下有可能存在目录或者文件,他们混在一起,所以我们很难进行操作和判断,如果直接操作的话,我们要先建立目录,才能定位文件。这个操作起来比较复制。 所以我想到的是,先复制目录的结构,再复制文件这个思路!下面是我的代码实现, 

       1.先写一个文件复制的操作方法

       2.复制目录结构的复制方法

      3. 递归源目标文件的方法

      4. 整合
%title插图%num

%title插图%num

%title插图%num

windows环境下java本地连接aws开发

1.首先需要参照本博客地址windows 安装aws cli 安装好aws cli,确保在dos命令行可以正常使用aws命令,正确安装好后会在当前用户目录下.aws文件夹下对应的密钥信息

2.java连接(可直接参照代码进行连接)

%title插图%num

这样便可以正常连接了。

————————————————

原文链接:https://blog.csdn.net/zhouyan8603/article/details/56015144

Android studio运行java程序

在写程序的时候总会遇到测试一个小的功能或者算法,这个时候如果每次都通过运行android程序来测试就太浪费时间了。studio也可以直接运行java程序。下面就直接贴步骤:

1 在已经建立的项目中添加新的module,然后选择JavaLibrary

%title插图%num

%title插图%num

2 填写新的module的信息,然后会生成对应的module和类,这个时候会有新的build.gradle生成

 

%title插图%num

%title插图%num

3这个时候已经完成了创建。但是不能直接点击运行键,这个时候需要设置一下。然后选择application,通过配置Name,mainclass, module名称来实现运行的配置。

%title插图%num %title插图%num

4 配置之后就可以直接运行了。如果想要删除掉的话,直接在项目的settings.gradle文件中删除对应的module就可以。

%title插图%num %title插图%num

Android 对 JVM 生态圈的兼容*限在哪里?

*近才意识到,实际上当年 Google 仅仅是把 Java 的 api 接口搬了过来,接口下面的代码完全重新写了一遍,虚拟机也是完全自己实现。这样的东西从标准来说应该不能算 JDK,本质其实是语法像 java 语言的全新语言。在当时确实可以把 java 生态圈里的很多东西,直接拿来用。

但是,我的疑惑是,这样的实现,它的技术*限在哪里,Google 是否真的做到了二进制级别的兼容?

12 条回复    2021-04-09 11:49:43 +08:00
guyeu
    1

guyeu   1 天前

显然没有,语法层面的兼容都没有做到,所以很多库会同时有 jre 版本和 android 版本。另外,Google 也复用了一大堆 JDK 的原始代码,后来因为官司问题都替换成了自己的实现而已。
abcbuzhiming
    2

abcbuzhiming   21 小时 32 分钟前

@guyeu 能不能举个同时有 jre 版本和安卓版本库的例子
guyeu
    3

guyeu   21 小时 25 分钟前

@abcbuzhiming #2 *著名的大概就是 guava 了
iminto
    4

iminto   20 小时 19 分钟前

@guyeu 这个例子不应该被认为是 API 不兼容导致,它的安卓版本是做了内存方面的优化和编码风格的改变,虽然某些 API 确实输出上有不同,但是 android 在语法层面应该认为是兼容某个特定 JRE 的。
ychost
    5

ychost   20 小时 8 分钟前

Guava 还好,后面 JDK 都借鉴了相关 api 比如 Optional,Future 之类的
wobuhuicode
    6

wobuhuicode   20 小时 7 分钟前

我记得 12 年刚学安卓 2.X 开发的时候,很多底层就是 JDK 的,好像安卓 4.4 之后才全部换过来。
bigbyto
    7

bigbyto   20 小时 6 分钟前

应该是取决于 android 的虚拟机。 很久没接触安卓,像早期的 dalvik 虚拟机,dex 是由 jvm bytecode(class 文件)转译过去的,因此一些新的 jvm 特性(如 invokedynamic 指令)需要等待安卓的虚拟机进行兼容,才能在代码中使用 lambda 表达式。
guyeu
    8

guyeu   19 小时 39 分钟前

@iminto #4 的确,guava 的 android 和 jre 版本更多在于编码风格和特定于 android 的优化。android 在编写和编译的层面也兼容某一个特定的 java 版本,可以说合法的 java 代码就是合法的 android 代码。不同的是运行时。
cjh1095358798
    9

cjh1095358798   19 小时 0 分钟前

android 符合 jvm 规范
ikas
    10

ikas   16 小时 46 分钟前

android 就是一个独立的平台,本身也是事实分裂了 java 生态,并且 android 的虚拟机不符合 jvm 规范,安卓跑的是 dex,jvm 跑的是 class, java 代码是先编译成 class,然后再转换成 dex.
ikas
    11

ikas   16 小时 33 分钟前

置于兼容,他根本不需要符合 jvm,同样也不需要去完整兼容,事实也是,他现在 java8 兼容完整了吗?
chenyu8674
    12

chenyu8674   1 小时 46 分钟前

java 程序员随便学两下就可以去写 Android,算不算另一种形式的“兼容”

常用的java应用服务器大概介绍

何为应用服务器呢?它主要为应用程序提供运行环境,为组件提供服务。想进一步了解,可以查看我的博客:何为容器?

Java 的应用服务器很多,从功能上分为两类:WEB 应用服务器和 Java EE 应用服务器。相对来说 Java EE 服务器的功能更加强大。

WEB 服务器

Tomcat 、Bejy Tiger 、Geronimo 、 Jetty 、Jonas 、Jrun 、Orion 、Resin。

Java EE 服务器

TongWeb 、BES Application Server 、 Apusic Application Server 、 IBM Websphere 、Sun Application Server 、Oracle 的 Oracle9i/AS 、Sun Java System Application Server 、Bea Weblogic 、JBoss、开源GlassFish。

下面简单介绍几个应用服务器。

Apache Tomcat
Tomcat是Apache 软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache、Sun 和其他一些公司及个人共同开发而成。由于有了Sun 的参与和支持,*新的Servlet 和JSP 规范总是能在Tomcat 中得到体现。因为Tomcat 技术先进、性能稳定,而且免费,因而深受Java 爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的Web 应用服务器。

优点:
1、免费的开源代码
2、轻量级应用服务器,在中小型 系统 和并发访问用户不是很多的场合下被普遍使用
3、占用的系统资源小,启动快
4、扩展性好,支持负载平衡与邮件服务等开发应用系统常用的功能

目前*新版本是8.0。

Jetty
Jetty 是一个开源的WEB容器,它为基于Java的web内容,例如JSP和servlet提供运行环境。Jetty是使用Java语言编写的,它的API以一组JAR包的形式发布。开发人员可以将Jetty容器实例化成一个对象,可以迅速为一些独立运行的Java应用提供网络和web连接。

优点:
1、免费的开源代码
2、轻量级,运行速度快。
3、易用
默认配置可以满足大部分的需求;将 Jetty 嵌入到应用程序当中只需要非常少的代码;
4、可扩展
Jetty 设计了非常良好的接口,用户可以非常方便地对 Jetty 的某些实现进行修改,使得 Jetty 适用于特殊的应用程序的需求。
5、易嵌入
Jetty 设计之初就是作为一个优秀的组件来设计的,这也就意味着 Jetty 可以非常容易的嵌入到应用程序当中。从某种程度上,你也可以把 Jetty 理解为一个嵌入式的Web服务器。

目前*新版本是:9.1.4

JBoss
JBoss是全世界开发者共同努力的成果,一个基于J2EE的开放源代码的应用服务器。因为JBoss代码遵循LGPL许可,可以在任何商业应用中免费使用它,而不用支付费用。2006年,Jboss公司被Redhat公司收购。JBoss 是一个管理EJB的容器和服务器,支持EJB 1.1、EJB 2.0和EJB3.0的规范。但JBoss核心服务不包括支持servlet/JSP的WEB容器,一般与Tomcat或Jetty绑定使用。
另外,JBoss在J2EE应用服务器领域已成为发展*为迅速的应用服务器.在市场占有率和服务满意度上取得了巨大的成功,丝毫不逊色于其它的非开源竞争对手,如WebSPhere、WebLogic、Application Server.

优点:

1、标准的开源J2EE容器
2、性能好,执行效率高
3、支持集群,理论上无*大访问量限制一说。
4、可伸缩性强
可伸缩性应该是架构选择的主要标准,所谓可伸缩性,只在小型系统、一台服务器情况下,我的系统也可以良好运转,多台服务器扩展后,我的系统只需通过增加硬件就可以实现性能扩展,无需修改太多软件。
5、支持热部署

目前JBOSS的*新版本号为7.1。

BEA WebLogic (收费)
WebLogic是Oracle的主要产品之一,是商业市场上主要的Java(J2EE)应用服务器软件(application server)之一,是世界上*个成功商业化的J2EE应用服务器。它是一套基于JAVA功能强大的电子商务套件,提供了许多功能强大的中间件以方便 编程 人员编写的JSP、SERVLET 等电子商务应用,可以为企业提供一个完整的商务应用解决方案。

优点:
1、标准
对业内多种标准的全面支持,使Web应用系统的实施更为简单。
2、可扩展性
WebLogic Server以其高扩展的架构体系闻名于业内,包括客户机连接的共享、资源pooling以及动态网页和EJB组件群集。
3、快速开发
凭借对EJB和JSP的支持,以及BEA WebLogic Server 的Servlet组件架 构体系,可加速投放市场速度。
4、更趋灵活
BEA WebLogic Server的特点是与* 数据库 、操作系统和Web服务器紧密集成。
5、可靠性
其容错、系统管理和安全性能已经在全球数以千记的关键任务环境中得以验证。

目前WEBLOGIC*新版本号为:12c

IBM WebSphere (收费)
WebSphere Application Server 是一种功能完善、开放的Web应用程序服务器,是IBM电子商务计划的核心部分。WebSphere 是随需应变的电子商务时代的*主要的软件平台。使用它,你可以开发、部署和整合新一代的电子商务应用,如B2B电子商务,并支持从简单的网页内容发布到企业级事务处理的商业应用。

目前WEBSPHERE*新版本号为:8.5.5

BEA公司的Weblogic服务器和IBM的Websphere在J2EE应用服务器市场中占据*对主导地位,都是商用产品。而JBoss和Tomcat算是开源的应用服务器界的两大明星。个人愚见,如果开发的是大型的、开放的、需要安全级别较高的系统,*好选用WebLogic 或Websphere等商用应用服务器,如果你开发的系统是分布式的,而且仅仅在公司内部使用,那么你可以选择JBoss。当然,大家都知道Tomcat是一个web 应用服务器,如果你开发的系统较小型,不涉及分布式等,那Tomcat将是你不错的选择。

处理微信服务器发来的消息

package com.router.api.wechat.controller;

import java.io.IOException;
import java.io.PrintWriter;

import javax.jws.WebService;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.beans.factory.annotation.Autowired;

import com.router.api.wechat.service.CoreService;
import com.router.api.wechat.util.Tool;
import com.router.service.AccessTokenService;

@WebServlet(name=”Auth”,urlPatterns=”/Auth”)
public class CoreController extends HttpServlet{
@Autowired
private AccessTokenService accessTokenService;
/**
* 本类 是为了验证token
*
*/
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();
// 请求校验,若校验成功则原样返回echostr,表示接入成功,否则接入失败
if (Tool.checkSignature(signature, timestamp, nonce)) {
out.print(echostr);
}
out.close();
out = null;
System.out.println(“123131d31a23d1a31sd32a1d3a1d31ad54a6d4”);
}

/**
* 处理微信服务器发来的消息
*/
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// 消息的接收、处理、响应
// 将请求、响应的编码均设置为UTF-8(防止中文乱码)
request.setCharacterEncoding(“utf-8”);
response.setContentType(“text/html;charset=utf-8”);
// 调用核心业务类接收消息、处理消息
PrintWriter out = response.getWriter();
String respXml = CoreService.processRequest(request);

// 设置了utf-8 不管用的时候 可以试试
out.println(“<?xml version=\”1.0\” encoding=\”utf-8\”?>”);
out.println(respXml);
out.close();
out=null;

}
}

友情链接: SITEMAP | 旋风加速器官网 | 旋风软件中心 | textarea | 黑洞加速器 | jiaohess | 老王加速器 | 烧饼哥加速器 | 小蓝鸟 | tiktok加速器 | 旋风加速度器 | 旋风加速 | quickq加速器 | 飞驰加速器 | 飞鸟加速器 | 狗急加速器 | hammer加速器 | trafficace | 原子加速器 | 葫芦加速器 | 麦旋风 | 油管加速器 | anycastly | INS加速器 | INS加速器免费版 | 免费vqn加速外网 | 旋风加速器 | 快橙加速器 | 啊哈加速器 | 迷雾通 | 优途加速器 | 海外播 | 坚果加速器 | 海外vqn加速 | 蘑菇加速器 | 毛豆加速器 | 接码平台 | 接码S | 西柚加速器 | 快柠檬加速器 | 黑洞加速 | falemon | 快橙加速器 | anycast加速器 | ibaidu | moneytreeblog | 坚果加速器 | 派币加速器 | 飞鸟加速器 | 毛豆APP | PIKPAK | 安卓vqn免费 | 一元机场加速器 | 一元机场 | 老王加速器 | 黑洞加速器 | 白石山 | 小牛加速器 | 黑洞加速 | 迷雾通官网 | 迷雾通 | 迷雾通加速器 | 十大免费加速神器 | 猎豹加速器 | 蚂蚁加速器 | 坚果加速器 | 黑洞加速 | 银河加速器 | 猎豹加速器 | 海鸥加速器 | 芒果加速器 | 小牛加速器 | 极光加速器 | 黑洞加速 | movabletype中文网 | 猎豹加速器官网 | 烧饼哥加速器官网 | 旋风加速器度器 | 哔咔漫画 | PicACG | 雷霆加速