我正在关注this教程。我已经使DNSMasq正常工作,但是尝试使用此脚本生成自签名证书时出现权限错误:
#!/usr/bin/env sh
cat > openssl.conf <<-EOF
[req]
distinguished_name = site_distinguished_name
x509_extensions = v3_site
prompt = no
[site_distinguished_name]
CN = *.${PWD##*/}.dev
[v3_site]
keyUsage = keyEncipherment, dataEncipherment
extendedKeyUsage = serverAuth
subjectAltName = @domains
[domains]
DNS.1 = *.${PWD##*/}.dev
DNS.2 = ${PWD##*/}.dev
EOF
openssl req -new -newkey rsa:2048 -sha256 \
-days 3650 -nodes -x509 -keyout site.key \
-out site.crt -config openssl.conf
这是我在航站楼里得到的
project_directory $ ./ssl_cert_gen.sh
-bash: ./ssl_cert_gen.sh: Permission denied
project_directory $ sudo ./ssl_cert_gen.sh
Password:
sudo: ./ssl_cert_gen.sh: command not found
我要走吗?有任何想法吗?提前致谢。
最佳答案
您必须使脚本可执行:
$ chmod +x ssl_cert_gen.sh
Unix中的所有可执行文件都必须设置相应的可执行(
x
)位,否则内核将不会执行它们。脚本也是可执行文件,但是它们利用“ shebang”机制(#!
)指定解释器的名称。关于macos - 生成自签名SSL证书,权限错误(OSX),我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/25766914/