Hello,World 百态
来源:互联网 发布:歼-16知乎 编辑:程序博客网 时间:2024/06/05 05:11
最简陋HelloWorld 首先,编写一个页面文件叫:hello.page,输入下面的信息,然后运行之!
1Hello!name
浏览器URL:http://localhost:/hello.page
运行结果如下:
浏览器URL:http://localhost:/hello.page?name=abc
运行结果如下:
1Hello:abc
很明显,上面的HelloWorld仅仅是在展现层完成的,不管怎么样,他不是用JS直接在页面输出的。
增加HelloWorld处理类
1
2
3
4
5
6
7
8
9
10
11
12
13@ServiceComponent()
public class HelloWorldService {
@ServiceMethod(serviceId = "helloWorldService")
@ServiceResult(name = "sayHelloResult")
@ServiceViewMapping(type="page",path="/helloworld.page")
public String helloWorld(String name) {
if (name == null) {
return "您好,guest!";
} else {
return "您好," + name;
}
}
}
编写helloworld.page文件,内容如下:
1$!sayHelloResult
浏览器URL:http://localhost:8080/helloWorldService.servicepage
运行结果如下:
1您好,guest!
浏览器URL:http://localhost:8080/helloWorldService.servicepage?name=abc
运行结果如下:
1您好,abc
好的,现在已经写了Java类,并且写了展现页面,并且已经正确的执行了结果。
换一种访问方式,试试看?
浏览器URL:http://localhost:8080/helloWorldService.servicexml?name=abc
1<string>您好,abc</string>
换一种访问方式,试试看?
浏览器URL:http://localhost:8080/helloWorldService.servicejson?name=abc
1<string>您好,abc</string>
运行结果如下:
1"您好,abc"
限于时间关系,怎么通过webservice访问就不再展示了,实际上,通过WebService访问也是没有问题的。
小结:只要定义一个Service,就可以用N种方式来访问它。
可以渲染为一个html页面,也可以渲染为了个JSon,也可以是一段Xml,还可以是一个Excel表格,等等。
这个时候,我们在4台机器上运行,其中一台配置为AR,两台配置为AS,一台配置为SC。
AR为Web接入服务器,AS为应用服务器,SC为服务中心,这个时候用JMeter来对AR进行并发访问,你会发现两台AS都在提供服务。这证明了你的应用服务已经可以进行水平扩展了,而且是基于SOA模式的。
同样的去访问WebService,你会发现,也会被负载给两台AS。
也就是说,你只写一次,就可以以各种方式向外提供服务。
当然,你看到了,在你的服务处理类上定义了我们的注解,这会对你的代码形成侵入性。
如果一点也不想依赖我们的类和接口,那也没有问题。
类的写法如下:
1
2
3
4
5
6
7
8
9public class HelloWorldService {
public String helloWorld(String name) {
if (name == null) {
return "您好,guest!";
} else {
return "您好," + name;
}
}
}
另外添加如下配置:
hello.service.xml
1
2
3
4
5
6
7
8
9
10
11
12<service-components>
<service-component type="org.tinygroup.helloproject.HelloWorldService">
<service-method service-id="helloWorldService" method-name="helloWorld">
<service-parameters>
<service-parameter name="name" type="java.lang.String"
required="true" is-array="false" />
</service-parameters>
<service-result name="sayHelloResult" required="true"
is-array="false" type="java.lang.String" />
</service-method>
</service-component>
< /service-components>
hello.serviceMapping.xml
1
2
3<service-mappings>
<service-mapping service="helloWorldService" type="page" path="/helloworld/helloworld.page<span></span>"></service-mapping>
< /service-mappings>
这种方式与用注解方式达到的结果是完全一样的。
通过Hello的了解,您可能知道了Tiny框架的一些特点,这里小结一下:
1Hello!name
浏览器URL:http://localhost:/hello.page
运行结果如下:
浏览器URL:http://localhost:/hello.page?name=abc
运行结果如下:
1Hello:abc
很明显,上面的HelloWorld仅仅是在展现层完成的,不管怎么样,他不是用JS直接在页面输出的。
增加HelloWorld处理类
1
2
3
4
5
6
7
8
9
10
11
12
13@ServiceComponent()
public class HelloWorldService {
@ServiceMethod(serviceId = "helloWorldService")
@ServiceResult(name = "sayHelloResult")
@ServiceViewMapping(type="page",path="/helloworld.page")
public String helloWorld(String name) {
if (name == null) {
return "您好,guest!";
} else {
return "您好," + name;
}
}
}
编写helloworld.page文件,内容如下:
1$!sayHelloResult
浏览器URL:http://localhost:8080/helloWorldService.servicepage
运行结果如下:
1您好,guest!
浏览器URL:http://localhost:8080/helloWorldService.servicepage?name=abc
运行结果如下:
1您好,abc
好的,现在已经写了Java类,并且写了展现页面,并且已经正确的执行了结果。
换一种访问方式,试试看?
浏览器URL:http://localhost:8080/helloWorldService.servicexml?name=abc
1<string>您好,abc</string>
换一种访问方式,试试看?
浏览器URL:http://localhost:8080/helloWorldService.servicejson?name=abc
1<string>您好,abc</string>
运行结果如下:
1"您好,abc"
限于时间关系,怎么通过webservice访问就不再展示了,实际上,通过WebService访问也是没有问题的。
小结:只要定义一个Service,就可以用N种方式来访问它。
可以渲染为一个html页面,也可以渲染为了个JSon,也可以是一段Xml,还可以是一个Excel表格,等等。
这个时候,我们在4台机器上运行,其中一台配置为AR,两台配置为AS,一台配置为SC。
AR为Web接入服务器,AS为应用服务器,SC为服务中心,这个时候用JMeter来对AR进行并发访问,你会发现两台AS都在提供服务。这证明了你的应用服务已经可以进行水平扩展了,而且是基于SOA模式的。
同样的去访问WebService,你会发现,也会被负载给两台AS。
也就是说,你只写一次,就可以以各种方式向外提供服务。
当然,你看到了,在你的服务处理类上定义了我们的注解,这会对你的代码形成侵入性。
如果一点也不想依赖我们的类和接口,那也没有问题。
类的写法如下:
1
2
3
4
5
6
7
8
9public class HelloWorldService {
public String helloWorld(String name) {
if (name == null) {
return "您好,guest!";
} else {
return "您好," + name;
}
}
}
另外添加如下配置:
hello.service.xml
1
2
3
4
5
6
7
8
9
10
11
12<service-components>
<service-component type="org.tinygroup.helloproject.HelloWorldService">
<service-method service-id="helloWorldService" method-name="helloWorld">
<service-parameters>
<service-parameter name="name" type="java.lang.String"
required="true" is-array="false" />
</service-parameters>
<service-result name="sayHelloResult" required="true"
is-array="false" type="java.lang.String" />
</service-method>
</service-component>
< /service-components>
hello.serviceMapping.xml
1
2
3<service-mappings>
<service-mapping service="helloWorldService" type="page" path="/helloworld/helloworld.page<span></span>"></service-mapping>
< /service-mappings>
这种方式与用注解方式达到的结果是完全一样的。
通过Hello的了解,您可能知道了Tiny框架的一些特点,这里小结一下:
- 可以没有任何侵入性,但是需要写一些xml文件
- 如果可以接受一些注解,那么开发将更加简单
- 开发了服务,就代表着可以做许多扩展的功能,而这些扩展的功能,不会要你做额外的工作
- Tiny框架中的Service与Spring中的Service的函义不同,它等价于WebService中的Service,就是说:你不用管它在哪里,实际上你也不知道它是在哪台物理机器上运行的,总之它被执行了。
- Tiny框架天生支持前后台服务器的水平扩展,而你不需要做任何针对性的开发-当然需要遵守其规约--所有的要发布成服务的参数及返回值必须是可序列化的,其它没有任何附加条件。
- Tiny的界面开发
- Tiny的服务开发
0 0
- Hello,World 百态
- Hello,World 百态
- Hello World!【Hello World】
- Hello, world!
- Hello World!
- Hello world!
- Hello World!
- Hello World!
- hello world!
- Hello World !
- Hello,World!
- Hello World!
- Hello world!
- Hello World!
- Hello World
- Hello World
- Hello world
- Hello World!
- mongoDB 介绍(特点、优点、原理)
- 如何让Web.xml变得简洁?
- 装VS遇到的小小问题
- CMakeLists2
- Linux部署Tomcat服务器
- Hello,World 百态
- jquery计算数组个数
- 关于系统首页绘制问题(ext布局+c#后台添加数据)经html输出流输出响应客户端
- 创建session的方法
- CMakeLists3
- 关于中文处理方面的研究
- FLOYD算法
- ManyToOne 详解
- linux java怎么安装