首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

xwiki开发者指南-脚本API指南

请注意,虽然大多数的例子都用Velocity编写,但你可以使用任何其他脚本语言来访问相同的API。 查询文档 查看查询模块了解有关如何在wiki使用脚本语言执行查询的例子。...例如,在Velocity,访问请求中传递的action HTTP参数,可以这样写: $request.action 请注意,这有一个快捷方式: $request.get("action") 获取外部内容...例子: $xwiki.getURLContent("http://google.com") 添加对象到页面 这里是Velocity脚本来显示如何在一个页面存储新的对象: ## Create an object...访问一个页面的对象 这里是Velocity脚本来显示它是如何访问附在页面的对象,并读取其字段: ## Retrieve the first object (index [0]) among all objects...从任何页面访问对象和在相同类遍历所有对象 这里是Velocity脚本来显示它是如何从另一个页面访问页面中的对象,并读取其字段: (类似于先前的代码,除了你需要在$xwiki.getDocument之前

1.5K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    浏览器中存储访问令牌的最佳实践

    出于可用性原因,JavaScript应用程序通常不会按需请求访问令牌,而是存储它。 问题是,如何在JavaScript中获取这样的访问令牌?...然而,攻击者无法读取响应,所以他们通常以一次性状态更改请求为目标,如更新用户的密码。 跨站脚本(XSS) 跨站脚本(XSS)漏洞允许攻击者将恶意的客户端代码注入到一个本来受信任的网站中。...浏览器中的存储解决方案 应用程序收到访问令牌后,需要存储该令牌以在API请求中使用它。浏览器中有多种方法可以持久化数据。应用程序可以使用专用API(如Web存储API或IndexedDB)来存储令牌。...但是,由于本地存储可以通过JavaScript访问,这意味着该解决方案也容易受到跨站脚本(XSS)攻击。...考虑并防止浏览器之外的攻击向量,如恶意软件、被盗设备或磁盘。 根据上述讨论,请遵循以下建议: 不要在本地存储中存储敏感数据,如令牌。 不要信任本地存储中的数据(尤其是用于认证和授权的数据)。

    26510

    分享一篇详尽的关于如何在 JavaScript 中实现刷新令牌的指南

    以下是应用程序如何在 Node.js 应用程序中使用 JWT 刷新令牌的示例: 用户登录到应用程序并将其凭据发送到身份验证服务器。 身份验证服务器验证凭据,生成 JWT 访问令牌和 JWT 刷新令牌。...客户端将令牌存储在本地存储中或作为仅 HTTP 的安全 cookie。 客户端在每个访问受保护资源的请求中发送访问令牌。 当访问令牌过期时,客户端将刷新令牌发送到认证服务器以获取新的访问令牌。...以下代码示例展示了如何在 Python 脚本中使用刷新令牌来确保用户的无缝体验: 此示例使用 jwt 库来解码 JWT 访问令牌,并使用 requests 库发出 HTTP 请求。...该脚本首先向令牌端点发出初始请求以获取访问令牌和刷新令牌。然后,对访问令牌进行解码以获取过期时间,并在向受保护端点发出请求之前检查该过期时间。...如果访问令牌已过期,脚本将使用刷新令牌来获取新的访问令牌,然后重试原始请求。

    36130

    聊一聊前端面临的安全威胁与解决对策

    防止未经授权的访问、数据泄漏和恶意活动对您的网络应用程序整体完整性的影响非常重要。您的前端可能会受到多种攻击,例如跨站点脚本(XSS),它会将恶意脚本注入您的网络应用程序,以针对其用户。...1、跨站脚本攻击(XSS): 跨站脚本攻击(XSS)是Web应用程序前端面临的最常见威胁之一。当攻击者将恶意脚本注入到多个网页中,并交付给您的Web应用程序的用户时,就会发生XSS攻击。..."> 2、在上面的 content 属性中,定义将允许用于脚本、样式、图像等多种类型内容的来源。您可以使用指令如 img-src 、 script-src 等来定义所有允许的域。...当用户登录您的Web应用程序或开始会话时,在服务器端生成一个唯一的CSRF令牌,并将其与用户的会话相关联。 2、在表单中或者您的AJAX请求的头部中,将CSRF令牌作为隐藏字段包含进去。...以下是如何在表单中包含CSRF令牌的方法: <input type="hidden" name="csrf_token

    55730

    Velocity语法大全

    在当前很多EasyJWeb的应用实践中,我们看到,所有界面模板中归纳起来只有下面四种简单模板脚本语句即可实现:1、$!obj  直接返回对象结果。 如:在html标签中显示java对象msg的值。...二、在EasyJWeb中的最佳实践 二、在EasyJWeb中的最佳实践 理论上你可以在EasyjWeb模板使用所有Velocity的脚本及功能,但我们不推荐你在界面模板中使用过多过复杂的脚本表达方式,在万不得已的情况下...在当前很多EasyJWeb的应用实践中,我们看到,所有界面模板中归纳起来只有下面四种简单模板脚本语句即可实现:1、$!obj  直接返回对象结果。 如:在html标签中显示java对象msg的值。...二、在EasyJWeb中的最佳实践 二、在EasyJWeb中的最佳实践 二、在EasyJWeb中的最佳实践 理论上你可以在EasyjWeb模板使用所有Velocity的脚本及功能,但我们不推荐你在界面模板中使用过多过复杂的脚本表达方式...在当前很多EasyJWeb的应用实践中,我们看到,所有界面模板中归纳起来只有下面四种简单模板脚本语句即可实现:1、$!obj  直接返回对象结果。 如:在html标签中显示java对象msg的值。

    1K20

    『互联网架构』软件架构-解密电商系统-Spring boot快速开始及核心功能介绍(下)(86)

    访问url,查看.127.0.0.1:8888 ? 多环境配置 我们在开发应用时,通常一个项目会被部署到不同的环境中,比如:开发、测试、生产等。...spring.velocity.expose-request-attributes = false #设置在与模板合并之前是否应将所有请求属性添加到模型中。...spring.velocity.expose-session-attributes = false #设置在与模板合并之前是否应将所有HttpSession属性添加到模型中。...spring.velocity.prefer-file-system-access = true #首选文件系统访问模板加载。文件系统访问可以对模板更改进行热检测。...spring.datasource.schema = #Schema(DDL)脚本资源引用。spring.datasource.separator =; #语句分隔符在SQL初始化脚本中。

    2.2K30

    Spring boot快速开始及核心功能介绍(下)

    在dev, test, prod这三个文件均都设置不同的server.port端口属性,如:dev环境设置为8081,test环境设置为8082,prod环境设置为8083 application.properties...spring.velocity.expose-request-attributes = false #设置在与模板合并之前是否应将所有请求属性添加到模型中。...spring.velocity.expose-session-attributes = false #设置在与模板合并之前是否应将所有HttpSession属性添加到模型中。...spring.velocity.prefer-file-system-access = true #首选文件系统访问模板加载。文件系统访问可以对模板更改进行热检测。...spring.datasource.schema = #Schema(DDL)脚本资源引用。 spring.datasource.separator =; #语句分隔符在SQL初始化脚本中。

    2K20

    【ASP.NET Core 基础知识】--安全性--防范常见攻击

    注入到页面:当其他用户访问包含恶意脚本的页面时,服务器将恶意脚本发送给用户的浏览器,并且浏览器在渲染页面时执行了这些恶意脚本。...XSS 攻击通常分为三种类型: 存储型 XSS:恶意脚本被存储在服务器上,当其他用户访问包含恶意脚本的页面时,会触发执行。...要防范CSRF攻击,通常需要采取一些措施,如使用CSRF令牌、同源检测等。...下面是一个简单的示例,演示如何在ASP.NET Core中配置和使用基本的身份验证和授权机制: 配置身份验证服务: 在Startup.cs文件的ConfigureServices方法中配置身份验证服务...六、总结 文章通过介绍常见的网络安全威胁,如跨站脚本(XSS)、SQL注入、CSRF等,并提供了相应的防御机制和实践建议。

    20000

    Velocity语法大全 转

    本文转载自:http://www.cnblogs.com/codingsilence/archive/2011/03/29/2146580.html 一、基本语法 1、"#"用来标识Velocity的脚本语句...3、"{}"用来明确标识Velocity变量; 比如在页面中,页面中有一个$someonename,此时,Velocity将把someonename作为变量名,若我们程序是想在someone这 个变量的后面紧接着显示...msg 二、在EasyJWeb中的最佳实践 理论上你可以在EasyjWeb模板使用所有Velocity的脚本及功能,但我们不推荐你在界面模板中使用过多过复杂的脚本表达方式,在万不得已的情况下,不要在界面模板中加入任何复杂的逻辑...在当前很多EasyJWeb的应用实践中,我们看到,所有界面模板中归纳起来只有下面四种简单模板脚本语句即可实现: 1、$!obj  直接返回对象结果。 如:在html标签中显示java对象msg的值。...如:#parse("/blog/top.html")或#include("/blog/top.html") parse与include的区别在于,若包含的文件中有Velocity脚本标签,将会进一步解析

    74340

    【网络安全】「靶场练习」(三)跨站请求伪造攻击 CSRF

    推荐文章:Swift 实现判断链表是否存在环:快慢指针法理由:文章详细讲解了如何在 Swift 中使用快慢指针技巧实现这一功能,同时对算法的时间与空间复杂度进行了深入分析。...与跨站脚本攻击(XSS)不同,CSRF 攻击并不需要注入恶意代码,而是利用了用户的身份认证和信任来进行操作。...1、攻击原理CSRF 攻击依赖于以下几个条件:用户已登录目标网站,并且其浏览器中保存了有效的认证凭据(如 cookie)。攻击者通过诱导用户访问恶意网站或点击恶意链接,自动向目标网站发送请求。...4、防御措施为了防御 CSRF 攻击,可以采取以下策略:使用 CSRF 令牌(token):每次表单提交或敏感请求中,附加一个随机生成的 CSRF 令牌,只有当请求携带正确的令牌时才会被认为是合法的。...双重提交 cookie:将 CSRF 令牌存储在 cookie 中,并在请求中同时提交该令牌。服务器会验证请求中的令牌是否与 cookie 中的值匹配。

    16710

    velocity:在eclipse和ultraedit中增加对vm脚本语法的高亮显示支持

    https://blog.csdn.net/10km/article/details/52329820 以前一直是用urltraedit来写velocity的脚本,因为没有语法高亮显示这一最基本的功能...最近又要写velocity脚本,实在不能忍了,去velocity的官网仔细研究了一下,原来虽然velocity没有提供velocity的专用编译器,但是有贡献者为velocity提供了在各种编辑器上的语法高亮等扩展支持...我常用的编译器是ultraedi和eclipse,所以根据《Velocity and Development Tools》中的说明,为ultraedit和eclipse分别增加了velocity支持。...首先打开http://wiki.apache.org/velocity/UltraEdit,复制页面中ultraedit.txt的内容,保存为一个文本文件(如ultraedit.uew)。...eclipse eclipse对velocity的支持是通过插件来实现的,根据《Velocity and Development Tools》中的说明可以找到好几个支持velocity的eclipse插件

    1.5K10

    Spring Boot 与 Spring Security 的集成及 OAuth2 实现

    使用 OAuth2 保护 API 为了保护我们的 API,使其只能通过 OAuth2 授权访问,我们需要将应用配置为资源服务器。资源服务器负责保护资源(如 API),并验证访问令牌的有效性。...前端集成与访问受保护的资源 在前端应用中(如使用 React 或 Angular),当用户通过 OAuth2 登录成功后,应用会获取到一个访问令牌。...我们从浏览器的 localStorage 中获取了访问令牌,并将其附加在请求头的 Authorization 字段中,以 Bearer 令牌的格式发送给后端服务器。...资源服务器会验证这个令牌的有效性,如果验证通过,则允许访问受保护的资源。 5....最后,我们展示了如何保护 API,使其只能通过 OAuth2 授权访问,并在前端应用中使用访问令牌请求受保护的资源。

    97710

    使用GitLabCI实现monorepos项目CICD

    如何在这样的项目中组织源代码?一种解决方案是monorepo,即项目中所有源代码在同一个存储库中管理。还有一种是每个微服务分别创建一个存储库管理。...monorepo方法允许轻松访问整个代码库,这带来了许多优势,例如易于代码重用、简化了依赖性管理。但每服务语义版本控制和部署过程将会更加复杂。...基本上,GitLab CI / CD管道包括几个阶段如build,test和deploy。该管道配置有一个名为.gitlab-ci.yaml的文件,该文件存储在我们存储库的根目录中。...在第一行中,我们使用用户名和访问令牌登录到GitLab Docker Registry,该用户名和访问令牌先前已在变量名称DOCKER_USER和中定义ACCESS_TOKEN(在GitLab项目的设置中...我们的服务测试可以在另一个job中执行,例如backend_test。所需的命令和脚本在很大程度上取决于我们项目的测试基础结构,但基本上,我们调用的脚本与在本地开发环境中使用的脚本相同。

    9.5K30
    领券