首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >AngularJS与JSP的集成

AngularJS与JSP的集成
EN

Stack Overflow用户
提问于 2015-05-29 10:15:16
回答 1查看 4.6K关注 0票数 3

目前,我们正在将应用程序从JSP迁移到AngularJS。组织决定一次只做一个模块。我们遇到的挑战之一是将用户数据从JSP传递到AngularJS (例如,index.html)。

我们希望如果调用AngularJS模块,系统将重新路由到由AngularJS管理的index.html。

我的问题是,我们可以用什么方法将用户数据(例如用户名)从JSP传输到index.html。

可能的情况:

  1. 用户登录到系统
  2. 用户转到角度管理模块。
  3. 系统将用户重定向到index.html (AngularJS)
  4. index.html将具有用户凭据(例如用户名和密码)
  5. AngularJS将在index.html中管理用户的操作,并使用用户的凭据向RESTful服务请求。

提亚

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-05-29 10:53:28

理想情况下,我不建议将usernamepassword注入index.html以供angularjs控制器/服务使用。如果用户在加载角托管页面时已经通过身份验证,那么要么注入授权令牌,要么安装浏览器将自动发送的cookie (假设jsp应用程序和角应用程序位于同一域中)。

现在,谈到为angularjs注入数据,我可以想到两种方法(我推荐第二种方法,因为它不会污染全球范围)

  1. 将其注入全局,并通过$window进行访问。就像。让服务器端.jsp使用全局变量呈现一个脚本标记,如

并使用$window在控制器中访问它。

代码语言:javascript
复制
    angular.module('yourapp').controller('YourCtrl', $window){
        console.log($window.pass);
    }
  1. 您可以使用角预紧将变量注入到type="text/preloaded"的脚本标记中,并通过$preloaded服务将其提供给控制器。

让jsp输出如下所示

代码语言:javascript
复制
<script type="text/preloaded">
{
  "data": "point"
}
</script>

然后把它放在你的控制器里,如下所示

代码语言:javascript
复制
angular.module('app', ['gs.preloaded'])
.controller('SomeCtrl', function ($preloaded) {
    // do something with $preloaded.
    $preloaded; // => { data: "point", another: { point: "of data" } }
});

记住将预加载的脚本放在控制器脚本之前,这样才能正常工作。从医生那里

注意:您的脚本标记必须在使用$preloaded之前运行,因此我建议将它们放在文档的头上。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30526999

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档