検索

我希望直接访问版本库中的 内容并且像访问目录一样,可以自动执行php,可以直接访问图片等。

在apache中已经加载了svn模块并且通过

<location> 
DAV svn 
SVNPath "/Users/mike/opt/svn" 
</location>

打开了svn的http访问。但是在http://localhost/svn中php会被直接打开(可以看到内容)而图片却打不开(一片空白)

回复内容:

我希望直接访问版本库中的 内容并且像访问目录一样,可以自动执行php,可以直接访问图片等。

在apache中已经加载了svn模块并且通过

<location> 
DAV svn 
SVNPath "/Users/mike/opt/svn" 
</location>

打开了svn的http访问。但是在http://localhost/svn中php会被直接打开(可以看到内容)而图片却打不开(一片空白)

apache的svn模块只能提供svn预览功能,是无法用来直接执行文件的。因为svn在服务器上不是按一个个文件存放的,而是以一定的格式存放在数据文件中。svn模块就是用来解析这种格式的。

如果你想svn提交后立即预览效果,可以使用svn hook的功能,所谓svn hook,就是允许你在提交版本之前或之后插入自己需要执行的命令。

首先在服务器上创建一个以后用来访问的web目录,比如这样(权限问题自己搞定)

mkdir /wwwroot/svn-preview/

在apache里面配置好这个目录的php运行环境,保证它可以被访问。
然后check out一份代码到这个目录(自己替换svn的url)

svn co http://my-svn-host/my-svn-path /wwwroot/svn-preview/ --username=my-svn-username

现在我们搞定了一份最新版的代码,并可以访问它了。然后要解决的是自动同步的问题。找到svn的repos目录,从你的例子上看,似乎是/Users/mike/opt/svn这个目录。

cd /Users/mike/opt/svn/hooks
ls

可以看到这里存放了很多hook的模版文件(以tmpl结尾的,你只需要把后缀名去掉,自己改动一下就可以生效了)。我们需要的是提交后同步,因此找到post-commit.tmpl,把他拷贝一份

cp post-commit.tmpl post-commit
chmod +x post-commit
vim post-commit

这时候打开了hook文件,里面有个例子是关于每次提交后发送个邮件提醒的,用#加在行首,把它们注释掉,我们用不着它。在最后面增加我们的命令,其实就是一行

svn up /wwwroot/svn-preview/ --username=my-svn-username --password=my-svn-password

提交个文件到svn,然后访问看看是不是正常同步了。

之前配置svn的时候还要加上字源编码才能同步
export LANG=zh_CN.UTF8
svn up /wwwroot/svn-preview/ --username=my-svn-username --password=my-svn-password

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
PHPはユーザーのセッションをどのように識別しますか?PHPはユーザーのセッションをどのように識別しますか?May 01, 2025 am 12:23 AM

phpidentifiesauser'ssessionsingsinssessionCookiesIds.1)whensession_start()iscalled、phpgeneratesauniquesidstoredsored incoookienadphpsessidontheuser'sbrowser.2)thisidallowsphptortorieSessiondatadata fromthata

PHPセッションを保護するためのベストプラクティスは何ですか?PHPセッションを保護するためのベストプラクティスは何ですか?May 01, 2025 am 12:22 AM

PHPセッションのセキュリティは、次の測定を通じて達成できます。1。session_regenerate_id()を使用して、ユーザーがログインまたは重要な操作である場合にセッションIDを再生します。 2. HTTPSプロトコルを介して送信セッションIDを暗号化します。 3。Session_Save_Path()を使用して、セッションデータを保存し、権限を正しく設定するためのSecure Directoryを指定します。

PHPセッションファイルはデフォルトで保存されていますか?PHPセッションファイルはデフォルトで保存されていますか?May 01, 2025 am 12:15 AM

phpsessionFilesToredInthededirectoryspecifiedBysession.save_path、通常/tmponunix-likesystemsorc:\ windows \ temponwindows.tocustomizethis:1)uesession_save_path()tosetaCustomdirectory、ensuringit'swritadistradistradistradistradistra

PHPセッションからデータをどのように取得しますか?PHPセッションからデータをどのように取得しますか?May 01, 2025 am 12:11 AM

toretrievedatafrompsession、Startthessession withsession_start()andAccessvariablesshe $ _SessionArray.forexample:1)Startthessession:session_start()

セッションを使用してショッピングカートを実装するにはどうすればよいですか?セッションを使用してショッピングカートを実装するにはどうすればよいですか?May 01, 2025 am 12:10 AM

セッションを使用して効率的なショッピングカートシステムを構築する手順には、次のものがあります。1)セッションの定義と機能を理解します。セッションは、リクエスト全体でユーザーのステータスを維持するために使用されるサーバー側のストレージメカニズムです。 2)ショッピングカートに製品を追加するなど、基本的なセッション管理を実装します。 3)製品の量管理と削除をサポートし、高度な使用状況に拡大します。 4)セッションデータを持続し、安全なセッション識別子を使用することにより、パフォーマンスとセキュリティを最適化します。

PHPでインターフェイスをどのように作成して使用しますか?PHPでインターフェイスをどのように作成して使用しますか?Apr 30, 2025 pm 03:40 PM

この記事では、PHPでインターフェイスを作成、実装、および使用する方法について説明し、コード組織と保守性の利点に焦点を当てています。

crypt()とpassword_hash()の違いは何ですか?crypt()とpassword_hash()の違いは何ですか?Apr 30, 2025 pm 03:39 PM

この記事では、PHPのCrypt()とpassword_hash()の違いについて、パスワードハッシュの違いについて説明し、最新のWebアプリケーションの実装、セキュリティ、および適合性に焦点を当てています。

PHPのクロスサイトスクリプト(XSS)をどのように防ぐことができますか?PHPのクロスサイトスクリプト(XSS)をどのように防ぐことができますか?Apr 30, 2025 pm 03:38 PM

記事では、入力検証、出力エンコード、およびOWASP ESAPIやHTML浄化器などのツールを使用して、PHPのクロスサイトスクリプト(XSS)を防止します。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。