PHP:创建文件并保留文件权限(PHP: Creating files and preserving file permissions)
我现在有一个简单的架构,看起来像这样:
用户发送电子邮件> Postfix> Procmail> PHP脚本>写入第三方Web App
第三方Web应用程序恰好是CMS(我使用其API来创建记录)。
我遇到的问题是用户正在向“支持”用户发送电子邮件,其中Web服务器在用户“apache”上运行。
由于此设置,所有附件都是使用“support”和“support”组创建的,但是我需要将它们实际创建为“apache:apache”(以便CMS可以读取和显示这些附件)在它的模板中)。
我知道PHP有chown和chmod函数,但是当尝试甚至从命令行运行这些命令时,我无法将文件的所有权移交给用户“apache”。
有没有一种简单的方法可以保留基于create目录的文件权限? 这是我需要从php.ini更改的内容吗? 或许我需要重新思考架构?
谢谢您的帮助!
I have a simple architecture at the moment which looks a little something like this:
User sends Email > Postfix > Procmail > PHP Script > Write to third party Web App
The third party web app happens to be a CMS (I am using its API to create records).
The problem that I am having is that users are sending Emails to the user of "support", where as the Web Server runs on the user "apache".
Because of this setup, all the attachments are being created with the user of "support" and the group "support", however I need them to actually be created as "apache:apache" (so that the CMS can read and display these attachments in it's templates).
I understand PHP has functions chown and chmod, however when trying to run these commands even from the command line, I am unable to handover ownership of the files to the user "apache".
Is there an easy way for me to preserve file permissions based on the create directory? Is this something I need to change from php.ini? Or perhaps I need to re-think the architecture?
Thanks for the help!
原文:https://stackoverflow.com/questions/4755014
最满意答案
这里有一个javascript脚本,可以完全满足您的需求
无需重新发明轮子:)
它检查高DPI显示如下:
Retina.isRetina = function(){ var mediaQuery = '(-webkit-min-device-pixel-ratio: 1.5), (min--moz-device-pixel-ratio: 1.5), (-o-min-device-pixel-ratio: 3/2), (min-resolution: 1.5dppx)'; if (root.devicePixelRatio > 1) { return true; } if (root.matchMedia && root.matchMedia(mediaQuery).matches) { return true; } return false; };
并使用以下内容添加后缀(默认为@ 2x)
var regexMatch = /\.[\w\?=]+$/; function suffixReplace (match) { return config.retinaImageSuffix + match; } function RetinaImagePath(path, at_2x_path) { this.path = path || ''; if (typeof at_2x_path !== 'undefined' && at_2x_path !== null) { this.at_2x_path = at_2x_path; this.perform_check = false; } else { if (undefined !== document.createElement) { var locationObject = document.createElement('a'); locationObject.href = this.path; locationObject.pathname = locationObject.pathname.replace(regexMatch, suffixReplace); this.at_2x_path = locationObject.href; } else { var parts = this.path.split('?'); parts[0] = parts[0].replace(regexMatch, suffixReplace); this.at_2x_path = parts.join('?'); } this.perform_check = true; } }
There's a javascript script for this that does exactly what you need
No need to reinvent the wheel :)
It checks for high DPI displays as follows:
Retina.isRetina = function(){ var mediaQuery = '(-webkit-min-device-pixel-ratio: 1.5), (min--moz-device-pixel-ratio: 1.5), (-o-min-device-pixel-ratio: 3/2), (min-resolution: 1.5dppx)'; if (root.devicePixelRatio > 1) { return true; } if (root.matchMedia && root.matchMedia(mediaQuery).matches) { return true; } return false; };
And uses the following to add the suffix, (by default @2x)
var regexMatch = /\.[\w\?=]+$/; function suffixReplace (match) { return config.retinaImageSuffix + match; } function RetinaImagePath(path, at_2x_path) { this.path = path || ''; if (typeof at_2x_path !== 'undefined' && at_2x_path !== null) { this.at_2x_path = at_2x_path; this.perform_check = false; } else { if (undefined !== document.createElement) { var locationObject = document.createElement('a'); locationObject.href = this.path; locationObject.pathname = locationObject.pathname.replace(regexMatch, suffixReplace); this.at_2x_path = locationObject.href; } else { var parts = this.path.split('?'); parts[0] = parts[0].replace(regexMatch, suffixReplace); this.at_2x_path = parts.join('?'); } this.perform_check = true; } }
相关问答
更多-
Chrome在低DPI和高DPI显示上重新分区滚动不同(Chrome repaints div on scroll differently on low- and high-DPI displays)[2022-02-17]
我没有一台Retina显示器电脑来测试。 我的猜测是你可以尝试.container上的“translateZ hack”? .container { -webkit-transform: translateZ(0); } 不知道这是否会起作用。 但在某些情况下,它通过将该元素分离到它自己的“图层”中来帮助修复浏览器重绘。 希望这可以帮助! I don't have a Retina display computer to test this with. My guess is you can try th ... -
ImageView怎么样? 它在正确的可见位置吗? 是否有其他视图与图像视图重叠? Ok so the only solution that I found for this issue is to delete the original file (non @2x) and leave the @2x file only en reference the regular file (non @2x) in the code or storyboard
-
不,但您需要设置background-size属性以匹配原始维度: @media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) { .box{ background:url('images/box-bg@2x.png') no-repeat top left; background-size: 200px 200px; } } 编辑 为了给这个答案添加一点,这里是我倾向于使用 ...
-
iOS 7 http://caniuse.com/#search=srcset不支持srcset srcset is not supported in iOS 7 http://caniuse.com/#search=srcset
-
在低DPI屏幕上显示高DPI图像的效果如何?(What is the effect of displaying a high DPI image on a low DPI screen?)[2022-12-22]
在DPI较低的屏幕上,高DPI图像会更大。 相反,在高dpi屏幕上,低dpi图像会更小。 这简化了一下。 这也取决于是否启用缩放。 如果您的资源中只有一个hdpi图像,并且您在ldpi屏幕上查看该图像,则根据您的设置,Android可能会向下缩放,在这种情况下,图像质量会稍微降低,相同的尺寸。 反过来说(hdpi上的ldpi缩放),你的hdpi屏幕上会有一个明显的像素化图像,缩放到相同的大小。 dpi真的不重要; 重要的是图像的实际物理尺寸。 如果您将更多像素挤入一英寸显示器(像素密度更高; hdpi),则 ... -
这里有一个javascript脚本,可以完全满足您的需求 Retina.js 无需重新发明轮子:) 它检查高DPI显示如下: Retina.isRetina = function(){ var mediaQuery = '(-webkit-min-device-pixel-ratio: 1.5), (min--moz-device-pixel-ratio: 1.5), (-o-min-device-pixel-ratio: 3/2), (min-resolution: 1.5dppx)'; ...
-
您必须向程序添加清单(或编辑现有清单)才能关闭DPI虚拟化。 它应该如下所示:
使用CSS [重复]以50%缩放显示高DPI图像(Display high-DPI image at 50% scaling using just CSS [duplicate])[2022-08-13]
设置width和height 据我所知,没有办法用CSS获取图像的尺寸。 使用JavaScript,您可以执行以下操作: var myImgs = document.getElementsByClassName('hidpi'); for (var i = 0; i < myImgs.length; i++) { var width = myImgs[i].naturalWidth, height = myImgs[i].naturalHeight; myImgs[i].width = ...尝试使用@"snow"而不是@"snow.png" 。 这样你就可以指向一个名为“snow”的图像,并让操作系统整理出有关分辨率和扩展的细节,而不是特别说明图像将被命名为"snow.png" Try using @"snow" instead of @"snow.png". This way you are pointing to an image named "snow" and letting the OS sort out the details regarding resolution and ex ...尝试自己设置设备像素比率。 使用具有不同像素比的多个显示器时,QPixmap无法正常工作。 也许这是你的问题。 因为QPixmaps中的devicePixelRatio始终是监视器中最高的。 但来自QWindow的信息是正确的。 所以来自QWindow的设置devicePixelRatio应该解决这个问题。 auto icon = QIcon(imageName); int pixelRatio = pFloatingEdit->window()->devicePixelRatio(); auto pxm ...相关文章
更多- Hadoop Java程序-files功能测试
- flume写入Hadoop hdfs报错 Too many open files
- elasticsearch too many open files
- PHP 中dirname(_file_)
- 用‘button’跟‘text’组合代替‘file’,选择文件后点‘submit’,‘file’的值被清空
- Java 流(Stream)、文件(File)和IO
- xxx is not in the sudoers file解决方法
- 【HDFS】HADOOP DISTRIBUTED FILE SYSTEM
- file_get_contents 无法读取https的问题解决!
- shell 脚本执行,出现错误bad interpreter: No such file or directory
最新问答
更多- h2元素推动其他h2和div。(h2 element pushing other h2 and div down. two divs, two headers, and they're wrapped within a parent div)
- 创建一个功能(Create a function)
- 我投了份简历,是电脑编程方面的学徒,面试时说要培训三个月,前面
- PDO语句不显示获取的结果(PDOstatement not displaying fetched results)
- Qt冻结循环的原因?(Qt freezing cause of the loop?)
- TableView重复youtube-api结果(TableView Repeating youtube-api result)
- 如何使用自由职业者帐户登录我的php网站?(How can I login into my php website using freelancer account? [closed])
- SQL Server 2014版本支持的最大数据库数(Maximum number of databases supported by SQL Server 2014 editions)
- 我如何获得DynamicJasper 3.1.2(或更高版本)的Maven仓库?(How do I get the maven repository for DynamicJasper 3.1.2 (or higher)?)
- 以编程方式创建UITableView(Creating a UITableView Programmatically)
- 如何打破按钮上的生命周期循环(How to break do-while loop on button)
- C#使用EF访问MVC上的部分类的自定义属性(C# access custom attributes of a partial class on MVC with EF)
- 如何获得facebook app的publish_stream权限?(How to get publish_stream permissions for facebook app?)
- 如何防止调用冗余函数的postgres视图(how to prevent postgres views calling redundant functions)
- Sql Server在欧洲获取当前日期时间(Sql Server get current date time in Europe)
- 设置kotlin扩展名(Setting a kotlin extension)
- 如何并排放置两个元件?(How to position two elements side by side?)
- 如何在vim中启用python3?(How to enable python3 in vim?)
- 在MySQL和/或多列中使用多个表用于Rails应用程序(Using multiple tables in MySQL and/or multiple columns for a Rails application)
- 如何隐藏谷歌地图上的登录按钮?(How to hide the Sign in button from Google maps?)
- Mysql左连接旋转90°表(Mysql Left join rotate 90° table)
- dedecms如何安装?
- 在哪儿学计算机最好?
- 学php哪个的书 最好,本人菜鸟
- 触摸时不要突出显示表格视图行(Do not highlight table view row when touched)
- 如何覆盖错误堆栈getter(How to override Error stack getter)
- 带有ImageMagick和许多图像的GIF动画(GIF animation with ImageMagick and many images)
- USSD INTERFACE - > java web应用程序通信(USSD INTERFACE -> java web app communication)
- 电脑高中毕业学习去哪里培训
- 正则表达式验证SMTP响应(Regex to validate SMTP Responses)