文档章节

ServiceStack 项目实例 008 ServiceStack.Examples - 2

丁川
 丁川
发布于 2016/10/02 12:05
字数 773
阅读 27
收藏 1

   先回归下SS的运行环境 

     wKiom1STuCCRipP3AAJMjYAmyzo242.jpg

 

          我们接续前文,说明一下ServiceStack.Examples中的实用经典的代码(下面的代码是更新成新版写法后的):

        

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

public object Any(GetUsers request)

        {

            using (var dbConn = ConnectionFactory.OpenDbConnection())

            {

                var users = new List<User>();

                if (request.UserIds != null && request.UserIds.Count > 0)

                {

                    users.AddRange(dbConn.GetByIds<User>(request.UserIds));

                }

                if (request.UserNames != null && request.UserNames.Count > 0)

                {

                    users.AddRange(dbConn.Select<User>(

                        "UserName IN ({0})", request.UserNames.SqlInValues()));

                }

                return new GetUsersResponse { data = users };

            }

 

          这段服务实现的功能是通过一组ID或者一组用户名为条件,搜索出一个用户列表。我们先看入口类的参数参数定义:

          

1

2

3

4

5

public class GetUsers

{

    public List<long> UserIds { getset; }

    public List<string> UserNames { getset; }

}

        入口类参数定义了两个列表,

1

UserIds

       为用户ID的一组列表 ,通过

1

dbConn.GetByIds<User>(request.UserIds)

查询到符合这组ID的用户列表, 再调用

1

users.AddRange

加入到出口类中的data属性上      

1

UserNames

       为用户名字的一组列表,通过

1

dbConn.Select<User>("UserName IN ({0})", request.UserNames.SqlInValues())

查询到一组包含有这组用户名的用户(是通过SQL的IN操作),再调用

1

users.AddRange

加入到出口类的data属性上

 

 

       出口类的定义:

1

2

3

4

5

6

7

8

9

10

public class GetUsersResponse

{

    public GetUsersResponse()

    {

        this.data = new List<User>();

        this.ResponseStatus = new ResponseStatus();

    }

    public List<User> data { getset; }

    public ResponseStatus ResponseStatus { getset; }

}

      出口类是有一个User实体类集合,加上一个操作相应状态类组成,原有出口类中用户列表使用的是Users属性(

1

this.Users = ArrayOfUser{get;set;}

),根据对接到extjs的要求,这个列表的属性要求名字为data,这里改为data,ArrayOfUser是一个用在旧版中的自定义的集合类,我们只需要使用List<User>即可,不需要定义这个集合

 

     以下是User实体类:

1

2

3

4

5

6

7

8

9

public class User

{

    [AutoIncrement]

    public int Id { getset; }

    public string UserName { getset; }

    public string Email { getset; }

    public string Password { getset; }

    public Guid GlobalId { getset; }

}

    

     ResponseStatus 是SS系统内置的HTTP相应状态类,其中封装了HTTP错误返回代码,错误消息以及错误堆栈等,而且提供了三种形式的覆写构造方式。 

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

// Summary:

    //     Common ResponseStatus class that should be present on all response DTO's

    [DataContract]

    public class ResponseStatus

    {

        // Summary:

        //     Initializes a new instance of the ServiceStack.ServiceInterface.ServiceModel.ResponseStatus

        //     class.  A response status without an errorcode == success

        public ResponseStatus();

        //

        // Summary:

        //     Initializes a new instance of the ServiceStack.ServiceInterface.ServiceModel.ResponseStatus

        //     class.  A response status with an errorcode == failure

        public ResponseStatus(string errorCode);

        //

        // Summary:

        //     Initializes a new instance of the ServiceStack.ServiceInterface.ServiceModel.ResponseStatus

        //     class.  A response status with an errorcode == failure

        public ResponseStatus(string errorCode, string message);

        // Summary:

        //     Holds the custom ErrorCode enum if provided in ValidationException otherwise

        //     will hold the name of the Exception type, e.g. typeof(Exception).Name A value

        //     of non-null means the service encountered an error while processing the request.

        [DataMember(Order = 1)]

        public string ErrorCode { getset; }

        //

        // Summary:

        //     For multiple detailed validation errors.  Can hold a specific error message

        //     for each named field.

        [DataMember(Order = 4)]

        public List<ResponseError> Errors { getset; }

        //

        // Summary:

        //     A human friendly error message

        [DataMember(Order = 2)]

        public string Message { getset; }

        //

        [DataMember(Order = 3)]

        public string StackTrace { getset; }

    }

 

更新了使用新版ServiceStack后的项目代码 

http://down.51cto.com/data/1964107 

本文转载自:http://soaop.blog.51cto.com/6164600/1591988

共有 人打赏支持
丁川
粉丝 4
博文 52
码字总数 4829
作品 0
南宁
程序员
加载中

评论(1)

丁川
丁川
已经不使用了,要收费,免费版本只有10个api的使用权限。
ServiceStack 简单使用

提到构建WebService服务,大家肯定第一个想到的是使用WCF,因为简单快捷嘛。首先要说明的是,本人对WCF不太了解,但是想快速建立一个WebService,于是看到了MSDN上的这一篇文章 Building Cro...

麦田守望者LEO
07/23
0
0
安装window下的redis,redis可视化管理工具(Redis Desktop Manager)安装,基础使用,实例化项目

以下包括内容: 一、redis下载安装,启动 二、Redis可视化管理工具(Redis Desktop Manager)安装 三、实例化项目 一、redis下载安装,启动 1,redis官方下载地址:https://redis.io/downlo...

saucxs
08/11
0
0
安装redis服务器 jedis分片存放数据到redis服务器

redis windows 下载地址:https://github.com/ServiceStack/redis-windows 一、下载的安装包解压到盘符的指定位置,如下结构:(纯手敲,如果有缺失,见谅) Redis.doc redis-benchmark.exe r...

薄暮凉年
2015/08/07
0
0
A Fast, Simple, Typed ORM for .NET

Join the ServiceStack Google+ group or follow @servicestack for updates. A Fast, Simple, Typed ORM for .NET OrmLite's goal is to provide a convenient, DRY, config-free, RDBMS-ag......

postdep
2014/09/12
0
0
(译)在ASP.NET Web API中使用Redis

本文将介绍如何在ASP.NET Web API应用程序中使用Redis作为数据存储。利用ServiceStack.Redis库以及它强类型的Redis 客户端,实现如何建模和存储一对多的关系,以及使用Autofac的Web API依赖注...

jieqiuming
2014/05/01
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

八大包装类型的equals方法

先看其中一个源码 结论:八大包装类型的equals方法都是先判断类型是否相同,不相同则是false,相同则判断值是否相等 注意:包装类型不能直接用==来等值比较,否则编译报错,但是数值的基本类型...

xuklc
40分钟前
1
0
NoSQL , Memcached介绍

什么是NoSQL 非关系型数据库就是NoSQL,关系型数据库代表MySQL 对于关系型数据库来说,是需要把数据存储到库、表、行、字段里,查询的时候根据条件一行一行地去匹配,当量非常大的时候就很耗...

TaoXu
昨天
0
0
890. Find and Replace Pattern - LeetCode

Question 890. Find and Replace Pattern Solution 题目大意:从字符串数组中找到类型匹配的如xyy,xxx 思路: 举例:words = ["abc","deq","mee","aqq","dkd","ccc"], pattern = "abb"abc ......

yysue
昨天
1
0
Linux | Redis

写在前面的话 常言道,不作笔记不读书。在下是深有体会啊,所以,跟我一起做下本节的笔记吧,或许多年以后,你一定会感谢今天的你。 安装 在官网的下载页 Redis Download 直接写了在Linux的安...

冯文议
昨天
2
0
NoSQL-memcached

NoSQL介绍 NoSQL叫非关系型数据库。而关系型数据库代表有MySQL。对于关系型数据库来说,是需要把数据存储到库、表、行、字段里,查询的时候根据条件一行一行地去匹配,当量非常大的时候就很...

ln97
昨天
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部