用grails来实现网站API的一个思路

众所周知,目前很多网站都提供了API的服务,其中也包括JavaEye。调用网站的API可以提供接口给其他系统使用,方便开发者实现mashup。

一般的API可以是web service,也可以是返回xml、json,其实web service也是返回xml。我们使用grails可以非常容易实现返回xml,而无需借助任何插件。当然在grails中使用web service也相当容易。

下面是一个API的controller:
import grails.converters.*

class ApiController {
def login = {
def userName = params.userName
def password = params.password
def user = User.findWhere(userName:userName,password:password)
if (user)
render user as XML
else
render(text:"<xml><user>not found user</user></xml>",contentType:"text/xml",encoding:"UTF-8")
}

}


这样访问http://localhost:8080/工程名称/api/login?userName=test&password=test

如果存在用户名为test 密码为test的用户,则返回类似如下的xml:
  <?xml version="1.0" encoding="UTF-8" ?> 
<user id="2">
<userName>test</userName>
<password>test</password>
</user>


如果不存在该用户 也会返回一段xml。

如果需要添加其他的方法供外界调用,只需增加一个action,将其render as xml

需要注意的一点是:如果使用了grails的filter,必须修改相应的filter,比如我的代码如下:
class LoginFilters {
def filters = {
loginCheck(controller:'*', action:'*'){
before = {
if (params.controller == "api") {
return true
}
if(!session.user) {
if( !actionName.equals('login') && !actionName.equals('doLogin') ) {
redirect(controller:'user',action:'login')
return false
}
}
}
}
}
}

这样,如果访问apicontroller,就可以返回xml,否则的话只能返回登陆页面

其他的client端或者别的,只需解析xml就能得到相应的数据。

比如:使用andorid做一个系统的客户端,该系统采用grails实现,首先第一步就需要登陆系统。登陆的话就要验证用户名和密码。

登陆的代码如下:
import org.apache.http.client.HttpClient;
import org.apache.http.client.ResponseHandler;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.BasicResponseHandler;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.params.HttpProtocolParams;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;

import android.app.Activity;
import android.app.Dialog;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;

/**
* @author Tony Shen
*
*/
public class LoginActivity extends Activity {

Button cancleButton; //取消按钮
Button loginButton; //登陆按钮
String responseBody = null;
String result = null;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.login);
validate();
}

private void validate() {
cancleButton = (Button) findViewById(R.id.cancel);
cancleButton.setOnClickListener(cancleListener);

loginButton = (Button) findViewById(R.id.login);
loginButton.setOnClickListener(loginListener);
}

// cancle按钮监听器
OnClickListener cancleListener = new OnClickListener() {
public void onClick(View v) {
Intent intent0 = new Intent(LoginActivity.this, LoginActivity.class);
startActivity(intent0);
}
};

// login按钮监听器
OnClickListener loginListener = new OnClickListener() {
public void onClick(View v) {
CharSequence userNameValue = ((EditText) findViewById(R.id.username)).getText();
CharSequence passwordValue = ((EditText) findViewById(R.id.password)).getText();

String url = "/TheSales/api/login";
String host = "192.168.1.2:8080";
String params = "userName="+userNameValue.toString()+"&password="+passwordValue.toString();
HttpClient httpclient = new DefaultHttpClient();
httpclient.getParams().setParameter(HttpProtocolParams.HTTP_CONTENT_CHARSET,"UTF-8");

HttpGet httpget = new HttpGet("http://"+host+url+"?"+params);
ResponseHandler<String> responseHandler = new BasicResponseHandler();
try {
responseBody = httpclient.execute(httpget, responseHandler);
Document document = DocumentHelper.parseText(responseBody);
Element root = document.getRootElement();
if("not found user".equals(root.elementText("user")))
{
showDialog(1);
} else {
Intent intent1 = new Intent(LoginActivity.this,c.class);
startActivity(intent1);
}
} catch (Exception e) {
e.printStackTrace();
}
}
};

protected Dialog onCreateDialog(int id) {
return buildDialog(LoginActivity.this);
}

private Dialog buildDialog(Context context) {
Dialog dialog = new Dialog(context);
dialog.setTitle("用户名或密码出错,请重新输入!");
return dialog;
}
}

LoginActivity主要是通过HttpClient模拟请求系统,调用网站的api,返回xml。然后解析xml验证是否存在该用户。

MainActivity的代码很简单,主要使用main.xml,如下:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="fill_parent"
android:layout_height="fill_parent">
<TextView android:id="@+id/android:empty"
android:layout_width="wrap_content"
android:layout_height="wrap_content" android:text="登陆成功!" />
</LinearLayout>


这样我们就可以登陆系统了,界面很简单,只不过是通过这个思路实现网站的API
[img]http://dl.iteye.com/upload/attachment/206548/84cb8a2d-11e1-3bce-84e8-376ce4b2c536.jpg[/img]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 简介 2. 起步 2.1 下载并安装Grails 2.2 创建一个Grails应用 2.3 Hello World示例 2.4 使用IDE 2.5 规约配置 2.6 运行Grails应用 2.7 测试Grails应用 2.8 部署Grails应用 2.9 所支持的Java EE容器 2.10 创建工件 2.11 生成Grails应用 3. 配置 3.1 基本配置 3.1.1 内置选项 3.1.2 日志 3.2 环境 3.3 数据源 3.3.1 数据源和环境 3.3.2 JNDI数据源 3.3.3 自动数据库移植 3.4 外部配置 3.5 定义版本 4. 命令行 4.1 创建Gant脚本 4.2 可复用的Grails脚本 4.3 脚本中的事件 4.4 Ant和Maven 5. 对象关系映射(GORM) 5.1 快速指南 5.1.1 基本的CRUD 5.2 在GORM中进行领域建模 5.2.1 GORM中的关联 5.2.1.1 一对一 5.2.1.2 一对多 5.2.1.3 多对多 5.2.2 GORM的组合 5.2.3 GORM的继承 5.2.4 集合、列表和映射 5.3 持久化基础 5.3.1 保存和更新 5.3.2 删除对象 5.3.3 级联更新和删除 5.3.4 立即加载和延迟加载 5.3.4 悲观锁和乐观锁 5.4 GORM查询 5.4.1 动态查找器 5.4.2 条件查询 5.4.3 Hibernate查询语言 5.5 高级GORM特性 5.5.1 事件和自动实现时间戳 5.5.2 自定义ORM映射 5.5.2.1 表名和列名 5.5.2.2 缓存策略 5.5.2.3 继承策略 5.5.2.4 自定义数据库标识符 5.5.2.5 复合主键 5.5.2.6 数据库索引 5.5.2.7 乐观锁和版本定义 5.5.2.8 立即加载和延迟加载 5.6 事务编程 5.7 GORM和约束 6. Web层 6.1 控制器 6.1.1 理解控制器和操作 6.1.2 控制器和作用域 6.1.3 模型和视图 6.1.4 重定向和链 6.1.5 控制器拦截器 6.1.6 数据绑定 6.1.7 XML和JSON响应 6.1.8 上传文件 6.1.9 命令对象 6.2 Groovy Server Pages 6.2.1 GSP基础 6.2.1.1 变量和作用域 6.2.1.2 逻辑和迭代 6.2.1.3 页面指令 6.2.1.4 表达式 6.2.2 GSP标签 6.2.2.1 变量和作用域 6.2.2.2 逻辑和迭代 6.2.2.3 搜索和过滤 6.2.2.4 链接和资源 6.2.2.5 表单和字段 6.2.2.6 标签作为方法调用 6.2.3 视图和模板 6.2.4 使用Sitemesh布局 6.3 标签库 6.3.1 简单标签 6.3.2 逻辑标签 6.3.3 迭代标签 6.3.4 标签命名空间 6.4 URL映射 6.4.1 映射到控制器和操作 6.4.2 嵌入式变量 6.4.3 映射到视图 6.4.4 映射到响应代码 6.4.5 映射到HTTP方法 6.4.6 映射通配符 6.4.7 自动重写链接 6.4.8 应用约束 6.5 Web Flow 6.5.1 开始和结束状态 6.5.2 操作状态和视图状态 6.5.3 流执行事件 6.5.4 流的作用域 6.5.5 数据绑定和验证 6.5.6 子流程和会话 6.6 过滤器 6.6.1 应用过滤器 6.6.2 过滤器的类型 6.6.3 过滤器的功能 6.7 Ajax 6.7.1 用Prototype实现Ajax 6.7.1.1 异步链接 6.7.1.2 更新内容 6.7.1.3 异步表单提交 6.7.1.4 Ajax事件 6.7.2 用Dojo实现Ajax 6.7.3 用GWT实现Ajax 6.7.4 服务端的Ajax 6.8 内容协商 7. 验证 7.1 声明约束 7.2 验证约束 7.3 客户端验证 7.4 验证和国际化 8. 服务层 8.1 声明式事务 8.2 服务的作用域 8.3 依赖注入和服务 8.4 使用Java的服务 9. 测试 9.1 单元测试 9.2 集成测试 9.3 功能测试 10. 国际化 10.1 理解信息绑定 10.2 改变Locales 10.3 读取信息 11. 安全 11.1 预防攻击 11.2 字符串的编码和解码 11.3 身份验证 11.4 关于安全的插件 11.4.1 Acegi 11.4.2 JSecurity 12 插件 12.1 创建和安装插件 12.2 理解插件的结构 12.3 提供基础的工件 12.4 评估规约 12.5 参与构建事件 12.6 参与运行时配置 12.7 运行时添加动态方法 12.8 参与自动重载 12.9 理解插件加载的顺序 13. Web服务 13.1 REST 13.2 SOAP 13.3 RSS和Atom 14. Grails和Spring 14.1 Grails的支柱 14.2 配置其他Bean 14.3 通过Beans DSL运行Spring 14.4 配置属性占位 14.5 配置属性重载 15. Grails和Hibernate 15.1 通过Hibernate注释进行映射 15.2 深入了解 16. 脚手架

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值