当前位置: 首页 > news >正文

镇江网站搜索引擎优化wordpress十佳主题

镇江网站搜索引擎优化,wordpress十佳主题,赤峰网站开发公司,wordpress 微信注册Spring MVC和AngularJs共同为构建表单密集型Web应用程序提供了一个真正高效且吸引人的前端开发堆栈。在这篇博客文章中#xff0c;我们将看到如何使用这些技术构建表单密集型Web应用程序#xff0c;并将这种方法与其他方法进行比较可用选项。 可以在此github 存储库中找到功能… Spring MVC和AngularJs共同为构建表单密集型Web应用程序提供了一个真正高效且吸引人的前端开发堆栈。在这篇博客文章中我们将看到如何使用这些技术构建表单密集型Web应用程序并将这种方法与其他方法进行比较可用选项。 可以在此github 存储库中找到功能完整且受保护的示例Spring MVC / AngularJs Web应用程序。我们将研究以下主题 Spring MVC Angular单页应用程序的体系结构 如何使用Angular构建Web UI 哪个Javascript / CSS库与Angular相辅相成 如何使用Spring MVC构建REST API后端 使用Spring Security保护REST API 与使用完全基于Java的方法的其他方法相比这又如何呢 Spring MVC Angular单页Web应用程序的体系结构 表单密集型企业级应用程序非常适合构建为单页Web应用程序。 与其他更传统的服务器端体系结构相比主要思想是将服务器构建为一组无状态可重用的REST服务并从MVC的角度将控制器从后端移出并移至浏览器中 客户端具有MVC功能并包含在视图层控制器层和前端服务层中分隔的所有表示逻辑。 初始应用程序启动后只有JSON数据通过客户端和服务器之间的连接。 后端是如何构建的 企业前端应用程序的后端可以以非常自然和类似于Web的方式构建为REST API。 可以使用相同的技术为第三方应用程序提供Web服务-在许多情况下不需要单独的SOAP Web服务堆栈。 从DDD的角度来看域模型保留在服务和持久层级别的后端。 通过有线只有DTO可以通过而域模型则不可以。 如何使用Angular构建Web应用程序的前端 前端应围绕特定于视图的模型不是域模型构建并且应仅处理表示逻辑而不能处理业务逻辑。 这些是前端的三层 视图层 视图层由HTML模板CSS和代表不同UI组件的任何Angular指令组成。 这是登录表单的简单视图示例 form ng-submitonLogin() nameform novalidate ng-controllerLoginCtrl fieldsetlegendLog In/legenddiv classform-fieldinput ng-modelvm.username nameusername required ng-minlength6 typetextdiv classform-fieldinput ng-modelvm.password namepassword required ng-minlength6 pattern(?.*\d)(?.*[a-z])(?.*[A-Z]).{6,} typepassword/div/div/fieldsetbutton typesubmitLog In/buttona href/resources/public/new-user.htmlNew user?/a/form 控制器层 控制器层由Angular控制器组成它们将从后端和视图检索的数据粘合在一起。 控制器初始化视图模型并定义视图应如何对模型更改做出反应反之亦然 angular.module(loginApp, [common, editableTableWidgets]) .controller(LoginCtrl, function ($scope, LoginService) {$scope.onLogin function () {console.log(Attempting login with username $scope.vm.username and password $scope.vm.password);if ($scope.form.$invalid) {return;}LoginService.login($scope.vm.userName, $scope.vm.password);};}); 控制器的主要职责之一是执行前端验证。 在前端进行的任何验证仅出于方便用户的目的-例如它们对于立即通知用户必填字段很有用。 由于安全原因任何前端验证都需要在后端在服务层级别重复进行因为可以轻松绕过前端验证。 前端服务层 一组允许与后端交互并可以注入到Angular控制器中的Angular服务 angular.module(frontendServices, []) .service(UserService, [$http,$q, function($http, $q) {return {getUserInfo: function() {var deferred $q.defer();$http.get(/user).then(function (response) {if (response.status 200) {deferred.resolve(response.data);}else {deferred.reject(Error retrieving user info);}});return deferred.promise;} 让我们看看还需要哪些其他库来启动前端并运行它。 哪些Javascript / CSS库是补充Angular所必需的 Angular已经提供了构建应用程序前端所需的大部分功能。 Angular的一些很好的补充是 雅虎仅有4k的一个易于主题化的纯CSS库名为PureCss 。 它的皮肤生成器可以轻松地基于基色生成主题。 它的BYOJ自带Java脚本解决方案有助于使事情保持“成角度的方式”。 功能性的程序库来处理数据。 这些年来似乎最常用维护和记录最完善的工具就是lodash 。 使用这两个库和Angular 几乎可以构建任何基于表单的应用程序 实际上不需要任何其他操作。 根据您的项目其他一些库可能是一个选项 像requirejs这样的模块系统很不错但是由于Angular模块系统不处理文件检索因此在requirejs和angular模块的依赖项声明之间引入了一些重复。 CSRF Angular模块用于防止跨站点请求伪造攻击。 国际化模块 如何使用Spring MVC构建REST API后端 后端是使用通常的后端层构建的 路由器层定义哪些服务入口点对应于给定的HTTP URL以及如何从HTTP请求中读取参数 服务层包含任何业务逻辑例如验证定义业务交易的范围 持久层将数据库映射到内存中的域对象或从中映射 目前最好仅使用Java配置来配置Spring MVC。 几乎不需要web.xml 请参阅此处的仅使用Java config的完全配置的应用程序示例。 服务和持久层是使用通常的DDD方法构建的因此让我们将注意力集中在路由器层上。 路由器层 用于构建JSP / Thymeleaf应用程序的相同Spring MVC批注也可以用于构建REST API。 最大的区别在于控制器方法不返回定义应渲染哪个视图模板的String。 相反 ResponseBody批注指示应该直接呈现controller方法的返回值并成为响应主体 ResponseBody ResponseStatus(HttpStatus.OK) RequestMapping(method RequestMethod.GET) public UserInfoDTO getUserInfo(Principal principal) {User user userService.findUserByUsername(principal.getName());Long todaysCalories userService.findTodaysCaloriesForUser(principal.getName());return user ! null ? new UserInfoDTO(user.getUsername(), user.getMaxCaloriesPerDay(), todaysCalories) : null; } 如果要使用ResponseBody注释该类的所有方法则最好使用RestController注释整个类。 通过添加Jackson JSON库方法返回值将直接转换为JSON而无需任何进一步配置。 也可以转换为XML或其他格式具体取决于客户端指定的Accept HTTP标头的值。 请参见此处的几个配置了错误处理的控制器的示例。 如何使用Spring Security保护REST API 可以使用Spring Security Java配置来保护REST API。 一个好的方法是使用带有回退到HTTP Basic身份验证的表单登录并包括一些CSRF保护以及强制所有后端方法只能通过HTTPS访问的可能性。 这意味着后端将为用户提供一个登录表单并在成功登录到浏览器客户端时分配一个会话cookie但是通过支持回退到HTTP Basic通过凭据通过Authorization HTTP标头传递凭据的非浏览器客户端它仍然可以很好地工作。 。 遵循OWASP的建议可以使REST服务达到最小的无状态唯一的服务器状态是用于身份验证的会话cookie以避免必须为每个请求通过电线发送凭据。 这是有关如何配置REST API安全性的示例 http.authorizeRequests().antMatchers(/resources/public/**).permitAll().anyRequest().authenticated().and().formLogin().defaultSuccessUrl(/resources/calories-tracker.html).loginProcessingUrl(/authenticate).loginPage(/resources/public/login.html).and().httpBasic().and().logout().logoutUrl(/logout);if (true.equals(System.getProperty(httpsOnly))) {LOGGER.info(launching the application in HTTPS-only mode);http.requiresChannel().anyRequest().requiresSecure();} 此配置仅涵盖安全性的身份验证方面选择授权策略取决于API的安全性要求。 如果您需要对授权进行非常细粒度的控制请检查Spring Security ACL是否适合您的用例。 现在让我们看一下这种构建Web应用程序的方法与其他常用方法的比较。 将Spring / MVC Angular堆栈与其他常见方法进行比较 这种将Javascript用作前端将Java用作后端的方法可以简化开发工作流程。 当后端运行时不需要任何特殊工具或插件即可实现完整的前端热部署功能只需使用您的IDE将资源发布到服务器即可例如 CtrlF10 IntelliJ中的CtrlF10 并刷新浏览器页面。 仍然可以使用JRebel重新加载后端类但是对于前端而言 不需要任何特殊的操作。 实际上可以通过使用json-server模拟后端来构建整个前端。 如果需要这将允许不同的开发人员并行构建前端和后端。 全栈开发的生产力收益 根据我的经验能够直接编辑Html和CSS而无需中间的任何间接层请参阅此处 与GWT和JSF进行的高级Angular比较 有助于减少工作量并使事情简单。 编辑保存刷新开发周期非常快速且可靠极大地提高了生产率。 当相同的开发人员同时构建Javascript前端和Java后端时将获得最大的生产率提高因为大多数功能通常都需要同时更改两者。 这样做的潜在缺点是开发人员还需要了解HtmlCSS和Javascript但这在最近几年中变得越来越常见。 根据我的经验与等效的完整Java解决方案相比使用全栈可以在很短的时间内实现复杂的前端用例用几天而不是几周的时间因此提高生产率使学习曲线绝对值得。 结论 Spring MVC和Angular的结合确实为构建表单密集型Web应用程序的新方法打开了大门。 这种方法所带来的生产率提高使其成为值得研究的替代方案。 请求之间不存在任何服务器状态除了身份验证cookie通过设计消除了整个类别的错误。 有关更多详细信息请查看github上的该示例应用程序 并让我们知道您对以下注释的想法/问题。 翻译自: https://www.javacodegeeks.com/2015/01/web-app-architecture-the-spring-mvc-angularjs-stack.html
http://www.zqtcl.cn/news/944821/

相关文章:

  • 专业制作标书网站地图优化
  • 广州建网站兴田德润团队什么是网络营销详细点
  • win7建网站教程wordpress chrome插件开发
  • 免费行情软件网站下载视频公司介绍ppt制作模板
  • wordpress快速建站wordpress短代码可视化
  • 餐饮型网站开发比较好看的网页设计
  • 网站管理包括潍坊网站建设优化
  • 南开集团网站建设网站服务器搭建
  • 网络的最基本定义泰安seo网络公司
  • 国外比较好的资源网站请人做外贸网站应注意什么问题
  • 人网站设计与制作什么是销售型网站
  • 最简单网站开发软件有哪些企业电子商务网站建设问题
  • 玉林网站制作简单的网站制作代码
  • 滨州建设厅网站长沙好的做网站品牌
  • 教务系统网站建设模板下载为网站开发
  • 成都市建设招标网站加载wordpress外部文件
  • 网站做兼容处理怎么浙江seo博客
  • 设计商城的网站建设电商网站建设与管理实践
  • 怎样建一个英文网站制作视频的手机软件
  • 昆明做网站费用被骗去国外做网站网站推广
  • 京东商城网站怎么做静态网页有什么特点
  • 网站上线准备工作网站源码运行
  • 视频剪辑自学网站wordpress怎样改头像
  • 女装网站模板青岛开发区网站
  • dede网站后台海外网络服务器
  • 三合一企业网站模板wordpress做的外贸网站
  • 常州做企业网站的公司亚马逊雨林有原始部落吗
  • 临沂网站设计哪家好qq浏览器网页版进入
  • seo资料站哔哩哔哩官方网站首页
  • 前端怎么做网站万网域名管理入口