草庐IT

token-auth-file

全部标签

java - 如何使用AOP拦截File、FileReader、FileWriter、FileInputStream、FileOutputStream的构造函数?

我想拦截File、FileReader、FileWriter、FileInputStream和FileOutputStream的构造函数,并防止任何文件名包含“..”(以防止路径遍历攻击)或“\0”(以防止文件名空字符攻击)。关于如何使用SecurityManager做同样的事情,我还有另一个悬而未决的问题,但还没有人回答它,所以我希望这种替代方法能奏效。这是用于tomcat上的springwebapp。我知道我可以通过创建自己的SafeFile、SafeFileReader等类并修改代码以使用它们来手动执行此操作。但是,我们的代码中有960个地方使用了这些对象的构造函数,所以我宁愿避

java - Jenkins 管道和 java.nio.file.* 方法的问题

我正在尝试使用java.nio.file.*中的方法在Jenkins管道中执行一些基本文件操作。无论代码存在于哪个节点block,代码都在主节点上执行。在管道中,我已经验证了各种节点block是正确的——它们唯一地标识特定节点。但是,pathExists(以及其他移动、复制或删除文件的代码)始终在主节点上执行。知道发生了什么或如何解决它吗?importjava.nio.file.*StringslavePath='C:\\Something\\only\\on\\slave\\node'StringmasterPath='D:\\Something\\only\\on\\master\

java - Spring WebFlux : Serve files from controller

来自.NET和Node我真的很难弄清楚如何将这个阻塞的MVCController转移到一个非阻塞的WebFlux注释Controller?我理解了这些概念,但未能找到合适的异步JavaIO方法(我希望它返回Flux或Mono)。@RestController@RequestMapping("/files")publicclassFileController{@GetMapping("/{fileName}")publicvoidgetFile(@PathVariableStringfileName,HttpServletResponseresponse){try{Filefile=ne

java - 将照片上传到 Google Photos API 不返回上传 token

我正在使用2018版的GooglePhotosAPI上传图片和媒体,如下所述:“UploadingBytes”当我上传新图片或视频时,我从未在响应正文中获得上传token。它总是一个空体,根据上面的链接,这意味着字节已经上传(但这是一个新的上传)。这是一个请求/响应示例:request:POSThttps://photoslibrary.googleapis.com/v1/uploadsrequestheaders:authorization:Bearerabcd1234X-Goog-Upload-Protocol:rawX-Goog-Upload-File-Name:20140317

java - CLIENT-CERT auth-method 可以与 tomcat 中的 JDBC 域一起使用吗?

JDBC域指定了一个用于身份验证的表结构,其中包含由属性userNameCol和userCredCol定义的列。这些对应于对FORM或BASIC身份验证方法有意义的用户和密码。它们是交互式的,需要客户的用户提供这两部分内容。返回什么证书?数据的例子是什么存储在userNameCol和userCredCol长什么样?是否有替代表这个领域的结构案例?PS-我使用的是tomcat5.5.x。 最佳答案 JDBCRealm支持客户端证书是的,它可以。但是,有一些怪癖需要注意。用户名用户名列应包含证书主体的专有名称,作为字符串。不幸的是,To

java - Java读写XML数据文件报错"Premature end of file"

我一直在使用JDOM库通过JavaServlet读写XML文件。问题是,当我使用AJAX向读取和写入XML文件中的数据的servlet发送许多请求时,很多时候它无法显示错误:文件过早结束。我怎样才能将所有这些读/写同步到文件或者有没有其他方法可以防止这些问题?如果需要更多详细信息,请告诉我。在这种情况下使用线程会有什么好处吗?非常感谢! 最佳答案 两种可能的解决方案是:将您的文件写入thename.xml.part,然后在完成/关闭后重命名为thename.xml,这使得写入更接近于原子性——只要确定完成,读者就无法读取它它仅查找“

java - File.length() 在 Java 中返回不正确的值

在文件对象上调用.length()时,超过2GB的文件返回不正确的值。这是在tomcat容器中运行的Web应用程序中发生的。例如,Windows报告为2,083,344,714字节的文件从Java返回为1887961088。以下是环境细节:jdk1.6.0_24(64位)JavaJotSpot(TM)64位服务器虚拟机(内部版本17.0-b17,混合模式)Tomcat6.0.29window服务器2008r2所以我立即怀疑与32位虚拟机有关,但一切似乎都在64位中运行。我完全被难住了,任何帮助将不胜感激,如果只是帮助开发一些测试以查看问题是否与以某种方式在32模式下运行的东西有关..编

java - 由于缺少 CSRF 'preserved state',Spring-Oauth2 访问 token 请求从未成功

过去几天我一直在努力实现springboot/springsecurity/和java配置与spring-security-oauth2一起工作。我已经设法解决了大部分困难,但我对现在出了什么问题感到困惑。我正在成功完成以下步骤:将用户发送给提供商以授权应用程序代表他们行事提示用户根据安全性登录提供商用户授权应用,重定向url将它们连同查询字符串中的?code=asdfa&state=asdfasf以原始url发送回客户端应用在这一点上,我相信使用AuthorizationCodeResourceDetails的任何东西都应该交换授权代码和客户端应用凭据以获取访问token。这是进程失

java - File.delete() 是否删除 File 对象的指针?

我和我的同事正在争论File.delete()方法在Java中的工作原理。在我们的代码中:FileoutFile=newFile("/dir/name.ext");if(outFile.exists())outFile.delete();FileInputStreaminStream=newFileInputStream(outFile);WriteFile.writeFile(inStream);//Writestheactualfile出于安全原因,我不能在此处包含writeFile的整个方法体,但在创建所需的数据库对象后,它会执行以下操作:BufferedOutputStream

java - Spring 安全中每个请求的不同 csrf token

我正在使用在我的springsecurityxml文件中标记一个web项目。并以一种形式发送csrftoken:但是在通过BurpSuite拦截请求时,我在每个请求上获得相同的csrftoken,直到session持续存在。在springsecurity中,有什么方法可以让每个请求发送与每个session不同的csrftoken。我正在使用3.2.4spring安全jar。 最佳答案 CSRFtoken的默认持续时间是session持续时间。CSRFtoken存储在HTTPsession中,因此是在每个session的基础上生成的。