我正在关注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
我离开了吗?有任何想法吗?提前谢谢。
答案 0 :(得分:1)
您必须使脚本可执行:
$ chmod +x ssl_cert_gen.sh
Unix中的所有可执行文件必须设置相应的可执行文件(x
),否则内核不会执行它们。脚本也是可执行文件,但它们使用&#34; shebang&#34;机制(#!
)指定解释器的名称。