之前已经分享过一篇基于Cocos2dx与服务器使用Socket进行通信的框架,还不太熟悉的请移步到如下博文中:
【C/S通信交互之Socket篇】Cocos2dx(Client)使用BSD Socket与Mina(Server)手机网游通信框架!
那么今天Himi来分享如何在cocos2dx中使用Http来访问Server端并且获取数据;
这里对于Server端,Himi选用,Jetty,对于Jetty不太熟悉的可以先自行baidu~google~是个servlet的容器。类似JSP。 什么是servlet?jsp? = =。不赘述了。大家手动好吧;
下面我们简单书写一个Server端(如何创建一个Jetty服务器请看Himi Jetty 开发系列文章)
———–首先服务器端————–
这里就ibu写创建项目和配置项目的jar包 build path了。直接上主要代码段:
首先是Jetty Server主类:(这里Himi用的IDE 是 Eclipse)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
ServletServer.java
import org.eclipse.jetty.server.Server;
import org.eclipse.jetty.servlet.ServletContextHandler;
import org.eclipse.jetty.servlet.ServletHolder;
import servlet.HServlet;
/**
* @author Himi
*/
public class ServletServer {
public static void main(String[] args) throws Exception {
Server server = new Server(8080);
ServletContextHandler context = new ServletContextHandler(ServletContextHandler.SESSIONS);
context.setContextPath("/");
server.setHandler(context);
context.addServlet(new ServletHolder(new HServlet()), "/himi");
server.start();
server.join();
}
}
|
然后是我们的一个Servlet类:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
HServlet.java
package servlet;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* @author Himi
*/
public class HServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
public HServlet() {
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
System.out.println("~~~~有一个Clinet访问!~~~~");
//获取http Client端对应的两个字段的数据
String name = request.getParameter("name");
String password = request.getParameter("password");
//设置字符编码
response.setCharacterEncoding("UTF-8");
response.setContentType("text/html");
response.setStatus(HttpServletResponse.SC_OK);
response.getWriter().println("Server say: 测试中文:session=" + request.getSession(true).getId());
if(name!=null) {
response.getWriter().println("Server say:名字:"+name);
System.out.println("Client say: name="+name);
}
if(password!=null) {
response.getWriter().println("Server say:密码:"+password);
System.out.println("Client say: password="+password);
}
}
}
|
我们的Servlet里,就是得到http clinet端传过来的数据返回回去。中间简单写给客户端一些简单字符串~
OK,启动我们的Jetty服务器,右键ServletServer.java run,观察控制台:
|
2012-05-25 16:43:04.767:INFO:oejs.Server:jetty-8.1.3.v20120416
2012-05-25 16:43:05.110:INFO:oejs.AbstractConnector:Started SelectChannelConnector@0.0.0.0:8080
|
出现如上,表示你的Jetty Server启动成功;OK。然后设计客户端代码;
———–然后cocos2dx Clinet端————–
首先新建一个cocos2dx项目,这个不多说。然后在默认的HelloWorldScene.cpp 初始化函数替换如下代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
bool HelloWorld::init()
{
/*
*@author By Himi
*/
//////////////////////////////
// 1. super init first
if ( !CCLayer::init() )
{
return false;
}
CCLabelTTF* pLabel = CCLabelTTF::labelWithString("Hello World", "Thonburi", 34);
CCSize size = CCDirector::sharedDirector()->getWinSize();
pLabel->setPosition( ccp(size.width / 2, size.height - 20) );
this->addChild(pLabel, 1);
CURL *curl;
CURLcode res;
char buffer[10];
curl = curl_easy_init();
if (curl)
{
// curl_easy_setopt(curl, CURLOPT_URL, "http://127.0.0.1:8080/himi");
curl_easy_setopt(curl, CURLOPT_URL, "http://127.0.0.1:8080/himi?name=xiaoming&password=李华明");
res = curl_easy_perform(curl);
/* always cleanup */
curl_easy_cleanup(curl);
if (res == 0)
{
pLabel->setString("0 response");
}
else
{
sprintf(buffer,"code: %i",res);
pLabel->setString(buffer);
}
}
else
{
pLabel->setString("no curl");
}
return true;
}
|
OK,然后我们导入 curl.h头文件:
还没完,这时候提示我们找不到这个头文件,OK,继续操作两步如下:
1. 加入 libcurl.a 文件:(此文件默认在cocos2dx引擎包下的cocos2dx/platform/third_party/ios/libraries文件夹下)
别着急这时候还会提示头文件找不到;
在xcode中点击你的cocos2dx项目,然后选择你项目的 targets,然后在Build Settings中找到 Search Paths:
双击你的 Library Search Paths 观察:如下图:
下面那个”$…../third_party/ios/libraries”路径是你第一步添加lib curl.a的时候默认添加的。这个我们不要修改;但是请双击这个路径然后copy下来;
我们需要修改的是此属性的上一个属性,Header Search Paths;
双击Header Search Paths属性后面的连接,然后点击“+”号添加一个路径,这个路径就是刚才你copy的路径,但是粘贴后还要将此路径设置到上一个文件夹的路径;这么说有点绕,其实就是如下:
假设你之前copy的路径是 “$…../third_party/ios/libraries”
那么你在这里粘贴的时候路径应该是: “$…../third_party/ios”
OK,Himi这里的路径也截图给大家一张便于对比:
OK,如果以上步骤都操作正常那么编译将没有任何问题;
编译成功后,command+R运行项目,观察xcode控制台打印,以及服务器端打印:正常情况下应该如下:
OK,一切正常;
注意:用脚本新建的工程,默认是不加libcurl的,大家编译到其他平台的时候要修改makefile文件将其添加进去;(具体可以参考tests里面的makefile )
提醒 :这里客户端与服务器只是简单的http交互,没有更细节的处理,例如 Client端访问应该另起一个线程,交互的时候数据要有一定的协议规范等等这些在介绍Socket的时候都有说过了,这里就不多说了;