我如何列出一个私人Github回购作为“依赖”在package.json?我尝试了npm的Github url语法,如ryanve/example,但在包文件夹中进行npm安装会给出“无法安装”的私人依赖错误。是否存在依赖私有回购的特殊语法(或其他机制)?
当前回答
它可以通过https和oauth或ssh来完成。
HTTPS和oauth:创建一个具有“repo”作用域的访问令牌,然后使用以下语法:
"package-name": "git+https://<github_token>:x-oauth-basic@github.com/<user>/<repo>.git"
or
安装Ssh,然后使用下面的语法:
"package-name": "git+ssh://git@github.com:<user>/<repo>.git"
(注意在user前使用冒号而不是斜杠)
其他回答
如果有人正在为Git Lab寻找其他选项,而上面的选项不起作用,那么我们还有另一个选项。对于Git Lab服务器的本地安装,我们发现下面的方法允许我们包含包依赖项。为此,我们生成并使用一个访问令牌。
$ npm install --save-dev https://git.yourdomain.com/userOrGroup/gitLabProjectName/repository/archive.tar.gz?private_token=InsertYourAccessTokenHere
当然,如果以这种方式使用访问键,它应该具有有限的权限集。
好运!
它可以通过https和oauth或ssh来完成。
HTTPS和oauth:创建一个具有“repo”作用域的访问令牌,然后使用以下语法:
"package-name": "git+https://<github_token>:x-oauth-basic@github.com/<user>/<repo>.git"
or
安装Ssh,然后使用下面的语法:
"package-name": "git+ssh://git@github.com:<user>/<repo>.git"
(注意在user前使用冒号而不是斜杠)
NPM在回购中没有访问令牌
这种方法要求使用包的任何人都使用自己的个人访问令牌进行身份验证,而不是使用单个组令牌,这允许回购不含访问令牌。你也不需要每次用户不再被授予访问权时都创建一个新的访问令牌,相反,从GitHub的repo中删除用户将自动删除他们的包访问权。
这是GitHub的NPM指南的浓缩版:https://docs.github.com/en/packages/working-with-a-github-packages-registry/working-with-the-npm-registry
发布你的GitHub回购作为一个NPM包
在开发人员设置中创建个人访问令牌:https://github.com/settings/tokens 登录NPM
npm login --scope=@<USERNAME of repo owner in lowercase> --registry=https://npm.pkg.github.com
Username: <Your personal GitHub username>
Password: <Create a GitHub Access Token with your account and paste it here>
Email: <Email associated with the same account>
例如:用户@Bobby希望将github.com/Jessica/my-npm-package作为NPM包发布
npm login --scope=@jessica --registry=https://npm.pkg.github.com
Username: bobby
Password: yiueytiupoasdkjalgheoutpweoiru
Email: bobby@example.com
更新包。Json,按照下面的格式。
"name": "@jessica/my-npm-package",
"repository": "git://github.com/jessica/my-npm-package.git",
"publishConfig": {
"registry":"https://npm.pkg.github.com"
},
要发布NPM包,运行:
npm publish
在项目中安装一个私有NPM包
以与上面第2步完全相同的方式登录NPM。 使用npm Install @jessica/my-npm-package安装这个包
完成了!
如果你的项目有需要安装这个私有NPM包的GitHub Actions脚本,请继续阅读。
GitHub操作:如何安装一个私有NPM包
In a CI environment, you'll also need npm login to similarly authenticate. Otherwise, npm install will fail, since it doesn't have access to the private NPM package. One way to pre-configure this is to use a .npmrc file; however, this commits auth credentials to the repo with that file. So, another way is to use the NPM tool npm-cli-login. There is a requirement that you either use your own personal access token (not optimal: you leave the repo, CI breaks), or set up a GitHub account specifically for CI and create an access token with that account.
使用CI-only GitHub帐户创建访问令牌,或从您自己的GitHub帐户中获取访问令牌。 在回购设置中将该访问令牌作为“秘密”添加到您的回购中。 更新你的GitHub Actions工作流脚本,在你安装NPM之后和运行NPM install之前运行这一步:
- name: Login to GitHub private NPM registry
env:
CI_ACCESS_TOKEN: ${{ secrets.NAME_OF_YOUR_ACCESS_TOKEN_SECRET }}
shell: bash
run: |
npm install -g npm-cli-login
npm-cli-login -u "USERNAME" -p "${CI_ACCESS_TOKEN}" -e "EMAIL" -r "https://npm.pkg.github.com" -s "@SCOPE"
替换NAME_OF_YOUR_ACCESS_TOKEN_SECRET,用户名,电子邮件和范围。
例如
- name: Login to GitHub private NPM registry
env:
CI_ACCESS_TOKEN: ${{ secrets.MY_TOKEN }}
shell: bash
run: |
npm install -g npm-cli-login
npm-cli-login -u "ci-github-account" -p "${CI_ACCESS_TOKEN}" -e "ci-github-account@example.com" -r "https://npm.pkg.github.com" -s "@jessica"
完成了!
现在,当GitHub Actions稍后运行npm install时,脚本将可以访问私有npm包。
供你参考:如果你熟悉GitHub Actions,你可能会问为什么我们不能使用秘密。GITHUB_TOKEN哪个GitHub自动提供?原因在于秘密。GITHUB_TOKEN只能访问运行GitHub Actions的repo,它不能访问私有NPM包的repo。
我无法在Docker容器中使已接受的答案工作。
对我有用的是在一个名为.netrc的文件中设置来自GitHub的个人访问令牌
ARG GITHUB_READ_TOKEN
RUN echo -e "machine github.com\n login $GITHUB_READ_TOKEN" > ~/.netrc
RUN npm install --only=production --force \
&& npm cache clean --force
RUN rm ~/.netrc
在package.json
"my-lib": "github:username/repo",
虽然这是一个老问题,但在这里添加一个跨平台的答案。
npm v7访问node_modules中的私有存储库的通用语法是-
git+https://<token_name>:<token>@<path_to_repository>.git#<commit>
你必须用你的git服务提供者创建一个至少具有读访问权限的访问令牌。
以下是最流行的平台链接:
github gitlab bitbucket都
请注意,github创建的令牌链接到您的用户名,没有令牌名称,因此,使用您的用户名而不是token_name的github。
推荐文章
- Git分支:master vs. origin/master vs. remotes/origin/master
- 如何根据文件扩展名过滤git差异?
- 如何设置一个git项目使用外部回购子模块?
- Git同时在两个分支上工作
- Browserslist: canius -lite已经过时。请运行下一个命令' npm update caniuse-lite browserslist '
- 如何在Visual Studio中删除未推送的外向提交?
- 检查已安装的angular-cli版本?
- 如何将Blob转换为JavaScript文件
- Git在两个不同的文件之间的差异
- 我如何使用vimdiff来解决git合并冲突?
- 如何将更改提交到另一个预先存在的分支
- 如何用Express/Node以编程方式发送404响应?
- 为什么使用'git rm'来删除文件而不是'rm'?
- 我如何安装imagemagick与自制?
- 致命:git-write-tree:错误构建树