@RequestBody @ResponseBody

@RequestBody

	1) 该注解用于读取 Request 请求的 body 部分数据,使用系统默认配置的 HttpMessageConverter 进行解析,
把相应的数据绑定到要返回的对象上。 2) 再把 HttpMessageConverter 返回的对象数据绑定到 controller 中方法的参数上。 application/json, application/xml:这些格式的数据,必须使用 @RequestBody 来处理。 @ResponseBody 将 Controller 的方法返回的对象通过适当的转换器转换为指定的格式后,
写入到 response 对象的 body 区,通常用来返回 JSON数据 或 XML。 注意:在使用 @RequestMapping 后,返回值通常解析为跳转路径,
但是加上 @ResponseBody 后返回结果不会被解析为跳转路径,而是直接写入 HTTP response body 中。
比如异步获取 json 数据,加上 @ResponseBody 后,会直接返回 json 数据。

JPQL查询

查询一个对象的所有属性时,并不能像 MySQL 那样使用 * 号标志。

"SELECT c.name, c.age FROM Customer c WHERE c.id > ?"

默认情况下, 若只查询部分属性, 则将返回 Object[] 类型的结果,或者 Object[] 类型的 List。

也可以在实体类中创建对应的构造器, 然后再 JPQL 语句中利用对应的构造器返回实体类的对象。

"SELECT new Customer(c.name, c.age) FROM Customer c WHERE c.id > ?"

JPA Specifications

使用Specifications,必须继承JpaSpecificationExecutor接口。

public interface Specification<T> extends Serializable {
@Nullable
Predicate toPredicate(Root<T> root, CriteriaQuery<?> query, CriteriaBuilder criteriaBuilder);
} Root:
是查询结果的一个实体对象,也就是查询结果返回的主要对象。 CriteriaQuery:
是JPA标准,主要是构建查询条件的。
里面的方法都是各种查询方式:distinct、select、where、groupby、having、orderby。 CriteriaBuilder:
返回Predicate接口,其中包含between、gt(大于)、lt(小于)、not等操作。 Root:查询哪个表
CriteriaQuery:查询哪些字段,排序是什么
CriteriaBuilder:字段之间是什么关系,如何生成一个查询条件,每一个查询条件都是什么方式
Predicate:单独每一条查询条件的详细描述

URLDecoder URLEncoder 解决Get请求中文乱码问题

URLDecoder 和 URLEncoder:
用于完成普通字符串 和 application/x-www-form-urlencoded MIME 字符串之间的相互转换。 浏览器中的地址栏中所输入的URL包含中文字符时(一般是URL携带的参数),
浏览器首先会将这些中文字符进行编码然后再发送给服务器。
实际上,浏览器会将它们转换为 application/x-www-form-urlencoded MIME 字符串。 URLEncoder类包含一个encode(String s,String enc)静态方法:
它可以将普通字符串转换成application/x-www-form-urlencoded MIME字符串。 URLDecoder类包含一个decode(String s,String enc)静态方法:
它可以将application/x-www-form-urlencoded MIME字符串转成普通字符串; 在 Java 代码中的 URLEncoder.encode() 的字符串
可以在 JS 中用 decodeURIComponent() 还原成字符串。 在 JS 中用 encodeURIComponent() 的参数
可以在 Java 代码中可以用 URLDecoder.decode(request.getParameter("param"),"UTF-8") 还原成字符串。

RSS

RSS 指 Really Simple Syndication(真正简易联合)
RSS 使您有能力聚合(syndicate)网站的内容
RSS 定义了非常简单的方法来共享和查看标题和内容
RSS 文件可被自动更新
RSS 允许为不同的网站进行视图的个性化
RSS 使用 XML 编写 通过 RSS feed(RSS 通常被称为 News feed 或 RSS feed),
用户们可以使用 RSS 聚合器来更快地检查您的网站更新(RSS 聚合器是用来聚集并分类 RSS feed 的网站或软件)。 feed:
信源,英文是feed。
信息发布网站将网站全部或者部分信息整合到一个 RSS 文件中,这个文件就被称之为 feed 。
信源中包含的数据都是标准的 XML 格式,不但能直接被其他站点调用,也能在其他的终端和服务中使用。

RSS Feed

<?xml version="1.0" encoding="UTF-8" ?>
<rss version="2.0"> <channel>
<title>博客标题</title>
<link>博客地址</link>
<description>网站描述</description>
<item>
<title>第一篇</title>
<description>摘要</description>
<author>作者</author>
<pubDate>发布时间</pubDate>
<link>链接</link>
</item>
</channel> </rss> <channel> 元素用于描述 RSS feed。<channel> 元素有三个必需的子元素:
<title> - 定义频道的标题
<link> - 定义到达频道的超链接
<description> - 描述此频道 每个 <channel> 元素可拥有一个或多个 <item> 元素,用于定义 RSS feed 中的一篇文章或 "story"。 <item> 元素拥有三个必需的子元素:
<title> - 定义项目的标题
<link> - 定义到达项目的超链接
<description> - 描述此项目

发布自己的 RSS feed

只能当其他人能够找到您的 RSS 文档时,它才是有用的。

把您的 RSS 发布到 Web 上:

	1. 编写 RSS feed,为您的 RSS feed 命名(请注意文件必须有 .xml 的后缀)。

	2. 验证您的 RSS 文件(可以在 http://www.feedvalidator.org 找到很好的验证器)。

	3. 把 RSS 文件上传到您的 web 服务器上的 web 目录。

	4. 把页面按钮 RSS Logo 或  XML Logo 添加指向 RSS 文件的链接。

网站更新内容后,需要即时更新 RSS feed。

Halo(十二)的更多相关文章

  1. 前端开发中SEO的十二条总结

    一. 合理使用title, description, keywords二. 合理使用h1 - h6, h1标签的权重很高, 注意使用频率三. 列表代码使用ul, 重要文字使用strong标签四. 图片 ...

  2. CRL快速开发框架系列教程十二(MongoDB支持)

    本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框 ...

  3. 我的MYSQL学习心得(十二) 触发器

    我的MYSQL学习心得(十二) 触发器 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数 ...

  4. Web 前端开发精华文章推荐(jQuery、HTML5、CSS3)【系列十二】

    2012年12月12日,[<Web 前端开发人员和设计师必读文章>系列十二]和大家见面了.梦想天空博客关注 前端开发 技术,分享各种增强网站用户体验的 jQuery 插件,展示前沿的 HT ...

  5. 第十二章Fundamental Data Types 基本数据类型

    目录: 12.1 数值概论 12.2整数 12.3浮点数 12.4 字符和字符串 12.5布尔变量 12.6枚举类型 12.7具名常量 12.8数组 12.9创建你自己的类型 12.1   数值概论 ...

  6. [分享] IT天空的二十二条军规

    Una 发表于 2014-9-19 20:25:06 https://www.itsk.com/thread-335975-1-1.html IT天空的二十二条军规 第一条.你不是什么都会,也不是什么 ...

  7. Bootstrap <基础三十二>模态框(Modal)插件

    模态框(Modal)是覆盖在父窗体上的子窗体.通常,目的是显示来自一个单独的源的内容,可以在不离开父窗体的情况下有一些互动.子窗体可提供信息.交互等. 如果您想要单独引用该插件的功能,那么您需要引用  ...

  8. Bootstrap <基础二十二>超大屏幕(Jumbotron)

    Bootstrap 支持的另一个特性,超大屏幕(Jumbotron).顾名思义该组件可以增加标题的大小,并为登陆页面内容添加更多的外边距(margin).使用超大屏幕(Jumbotron)的步骤如下: ...

  9. Bootstrap <基础十二>下拉菜单(Dropdowns)

    Bootstrap 下拉菜单.下拉菜单是可切换的,是以列表格式显示链接的上下文菜单.这可以通过与 下拉菜单(Dropdown) JavaScript 插件 的互动来实现. 如需使用下列菜单,只需要在 ...

  10. AngularJs的UI组件ui-Bootstrap分享(十二)——Rating

    Rating是一个用于打分或排名的控件.看一个最简单的例子: <!DOCTYPE html> <html ng-app="ui.bootstrap.demo" x ...

随机推荐

  1. sql-hive笔试题整理 1 (学生表-成绩表-课程表-教师表)

    题记:一直在写各种sql查询语句,最长的有一百多行,自信什么需求都可以接,可......,想了想,可能一直在固定的场景下写,平时也是以满足实际需求为目的,竟不知道应试的题都是怎么出的,又应该怎么做.遂 ...

  2. php heredoc的用法详解

    Heredoc技术,在正规的PHP文档中和技术书籍中一般没有详细讲述,只是提到了这是一种Perl风格的字符串输出技术.但是现在的一些论坛程序,和部分文章系统,都巧妙的使用heredoc技术,来部分的实 ...

  3. Day1 方法的重载

    方法的重载 方法的标识符包括: 1.方法名称   2.方法的参数(参数类型和参数的数量) 方法的重载:方法名称相同 但是方法参数不同(1.参数类型不同 2.参数类型相同 但是参数个数不同 3.类型和个 ...

  4. 像计算机科学家一样思考python-第2章 变量、表达式和语句

    感想: 1.程序出现语义错误时,画状态图是一个很好的调试办法.打印出关键变量在不同代码处理后值的变化,就能发现问题的蛛丝马迹. 2.每当学习新语言特性时,都应当在交互模式中进行尝试,并故意犯下错误,看 ...

  5. Unity3D热更新方案网摘总结

    参考:http://blog.csdn.net/guofeng526/article/details/52662994 http://blog.csdn.net/u010019717/article/ ...

  6. jQuery基础--创建节点和 添加节点

    创建节点 $(function () { // var box = document.getElementById("box"); // // var a = document.c ...

  7. 学习mybaits用到的4张表

    items orderdetail orders user

  8. python阳历转农历

    # 引入日历库模块 import sxtwl # 日历中文索引 ymc = ["十一", "腊", "正", "二", ...

  9. mysql 主从复制 (1)

    Mysql主从配置 大型网站为了软解大量的并发访问,除了在网站实现分布式负载均衡,远远不够.到了数据业务层.数据访问层,如果还是传统的数据结构,或者只是单单靠一台服务器扛,如此多的数据库连接操作,数据 ...

  10. Java双链表

    一.概述 二.英雄类 class HeroNode { //值域 public int id; public String name; public String nickName; //指针域 pu ...