Research
Security News
Malicious npm Packages Inject SSH Backdoors via Typosquatted Libraries
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.
markdown-img-icexmoon
Advanced tools
A program for find and upload images in markdown file and will replace them.
English | 简体中文
This program is used to scan the markdown files in the working directory, find the local images in them and upload them to the sm.ms
image bed automatically, and generate a copy of the markdown using the network images to replace the local images, which is stored in the current_working_directory/markdown_image
directory.
By the above way, we can realize the automatic batch markdown image processing work to facilitate the later dissemination of markdown contents on the web.
This program will not change the original markdown file, please feel free to use it.
This program relies on sm.ms
image bed, please register your account and generate token by yourself.
Support for other image beds has been added, see features for details, but the default is still using sm.ms image bed.
Because the sm.ms
image bed interface has a call limit, if there is a picture upload error, it may be caused by frequent uploads, please wait for more than 1 minute and reuse this program.
Tencent Cloud Object Storage has been added as a image bed, when using it, you need to enter the corresponding mandatory parameters for connection, you can read the Tencent Cloud OSS User Guide for specific parameters, in addition, you need to set the object storage service to private write public read.
Currently this program only supports windows.
Theoretically supports all platforms that can run Python, but has not been tested on other platforms at this time.
sm.ms
access is not considered friendly in China, generated markdown copy immediately published on the network may show anti-theft chain and other images hanging, that is because the domestic CDN is relatively slow, wait for a period of time on the good.
This program is written in Python, you need to install the Python runtime environment, if you don't know how to install, you can read the python environment installation under windows.
Image bed name | Flag | Bed nature | Access token required | Notes |
---|---|---|---|---|
sm.ms | smms | Public | Yes | Default image bed, foreign old public image bed service provider, trustworthy, the disadvantage of domestic access is unstable. |
yujian | yujian | Public | Yes | A domestic image bed service, in addition to providing its own image bed service, also supports calling other image bed services through its API. |
ruyou | rruu | Public | Yes | As you can see and met with the same set of website code, the site is currently closed, the service is not available. |
ali | ali | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
Vim-CN | vimcn | Public | No | A foreign bed service provider, said to be the same old service provider, the same disadvantage of domestic access is unstable. |
Tencent Cloud COS | qcloud | Private | Yes | There is nothing to say, several private cloud storage in the most recommended, the disadvantage is that currently only provides a year of free credit, the expiration of the need to renew. |
Qiniu Cloud | qiniu | Private | Yes | Provide permanent free storage quota, the disadvantage is not to provide a domain name for the stored external links, you need to own a domain name and binding operation before you can use it. |
bilibili | bilibili | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
Sougou | sougou | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
Huluxia | huluxia | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
Catbox | catbox | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
360 | 360 | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
Tietu | postimages | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
58 | ai58 | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
Jitu | gtimg | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
Baitu | bkimg | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
Muke | muke | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
Upay Cloud | upyun | Private | Yes | Provide vouchers, the disadvantage is not to provide a domain name for the stored external links, you need to own a domain name and binding operation before you can use it. In addition, white whoring vouchers need to join the Alliance, and once a year audit. |
pip install markdown-img-icexmoon
pip install --upgrade markdown-img-icexmoon
Added console short command support, all functions can be called quickly via
pymdimg
.For example,
pymdimg -h
is exactly the same aspython -m markdown_img -h
.
python -m markdown_img -h
。Excute pymdimg -v
or pymdimg --version
.
English and Chinese are supported as working languages, the default is Chinese.
pymdimg -l en
to switch the working language.Enabling this feature will compress images over a certain size and then upload them to the image bed to save private storage space. The compressed intermediate images will be automatically deleted from the local area and will not affect the original local images.
pymdimg --compress
to set the relevant configuration and then turn it on.GIL and tinyPNG are currently supported, the former for local compression using a third-party Gillow package, and the latter for online compression using the online service tinyPNG.com, the latter is recommended because the latter is lossless compression, but the latter requires registration to generate an access token first, and free users have the number of calls: 500 per month.
Execute pymdimg -e tinyPNG
to switch.
The main function of this program, will scan the markdown file in the command line working directory, will replace the local image in it with a bed image and then generate a copy of the bed, the generated copy will be stored in the markdown_img
folder in the working directory.
python -m markdown_img
.working_directory/markdown_img
directory.
- The token is stored in the
main.config
file in the directory where the program is located. You can modify it yourself if you need to, or you can delete the configuration file and run the program again to enter it.- The command parameters of the program will be enriched and refined later.
- If the URL returned by the target image bed contains special characters such as Chinese or spaces, and your markdown text editor cannot preview the corresponding image properly, you may need to use URL ENCODE to process it, turn on this function by
pymdimg -u standard
, and regenerate the copy after turning on. This feature currently only works with Tencent OSS, because other image beds will not return Chinese URLs.- A copy can be generated using a specified configuration, such as
pymdimg --config normal
, which allows you to use a customized related configuration to complete this task without modifying the current configuration in specific scenarios, such as when you want compression not to apply in this task, or when you use large scale compression. See [Function: Backup system configuration] for the specific function of making related configurations.
If the copy of the image bed is intact, but the local images associated with the native markdown file are missing, you can use this function to try to recover them.
python -m markdown_img -m img_recove
- Because the network image bed is unstable, although the program itself has a timeout reconnection mechanism, if too many images are recovered, it is likely that the processing will be interrupted and the program will simply need to be rerun.
- The recovery logic is to compare the order of appearance of the images in the copy and the original, and recover them 1 to 1. So it is important to ensure that there is no difference between the two, and the program will interrupt when the number of both is different and prompt the user to confirm manually.
You can switch the image bed service in case a certain image bed is not available or the access is unstable.
Currently supported image beds are sm.ms, Ali, RuYu, Vim-CN, meet, Tencent cloud object storage (promotional link),Qiniu Cloud.
For a list of supported image beds, see Supported Image Bed Services.
python -m markdown_img -i ali
- You can check the help documentation for the specific image bed logo.
- Access tokens are required to switch the bed service and will be prompted to enter the appropriate access token in use.
- Some necessary information is required to use Tencent Cloud OSS, please read the notes for details.
- You need to provide the necessary information when using Qiniu Cloud Storage, where the DNS binding domain name needs to include the protocol, such as
http://example.domain.com
If a wrong access token is set for the image bed token, or if a new access token is regenerated on the image bed website, you can update the corresponding access token in the program.
python -m markdown_img -c smms
You can check the help documentation for specific parameters.
Part of the image bed configuration if more than one, you can use subcommands to modify only a single configuration, for example, only modify the Tencent cloud storage directory:
pymdimg -c qcloud --des_dir image
, if there are spaces in the middle of the target directory, you need to give will be wrapped in English double quotes, such as this:pymdimg -c qcloud --des_dir "我 love 你"
. After updating the configuration you can usepymdimg -v
to confirm that the configuration has been set correctly.
If you need to upload all the images in a directory to a webbed and create a markdown file as an index file, then this is the right function to use.
python -m markdown_img -s
- The index file will be regenerated each time it is run.
- The name of the generated index file is
markdown_img_index.md
, please make sure not to customize the file with the same name in the target directory.- You can use the specified configuration, such as
pymdimg -s --config normal
, as described in the relevant entry in [Generating a copy of the mapbed markdown].
If your original md file has been updated and you don't want to delete the corresponding copy file manually and want to regenerate it automatically, you can use this function.
python -m markdown_img -m refresh
Scans the current directory for the original md file, and if there is no copy, creates it directly. If there is a copy, but the original file is "newer" than the copy, the copy is recreated.
If necessary, the system configuration can be backed up by
pymdimg -m backup_config --name xxx
The --name
parameter is not required, if not specified a configuration backup file name will be generated based on the current time.
pymdimg --list_config
will list the configuration name and creation time
You can replace the current configuration with a saved configuration:
pymdimg --change_config xxx
where xxx
is the file name of the saved configuration you want to replace. To see what saved configurations are available, please use [Function: List saved configurations]. In addition, it is better to save the current configuration before using this function.
You can process the MD file using absolute path pictures to use relative path pictures, and the program will copy the original pictures to the images subdirectory of the current directory as relative path pictures.
The purpose of this function is to provide convenience for some cross-platform, multi-device users, using relative paths, raw images and MD files can be easily moved, or using a synchronization service similar to Nut Cloud for multi-device synchronization.
pymdimg -m relative_img
- In order to avoid the corruption of the original MD file caused by program errors, one original file will be kept and backed up in the backup subdirectory.
- Because of the difference between Windows and Linux platform separators, there is no guarantee that the relative directories of both will behave properly.
The developer of this application has received help and support from upyun for its free CDN acceleration and cloud storage services, if you want to get the same help and support, you can Click here to join.
Add globalization support. add English as a new working language.
Add Qiniu Cloud as a new optional image bed.
Add UPYun Cloud as a new optional image bed.
Add image compression feature.
Add TinyPNG as a new image compression engine.
Compression engine switch option add none, can be more convenient to turn off the compression function.
Add system configuration backup function.
Add the function of using specified configuration.
Fix the bug that can't install successful caused by use futures module.
Fix the bug that can't create img dir normally in Linux.
Added the function to modify the absolute path image in the MD file to relative path.
Added the support to fengzhen image bed.
FAQs
A program for find and upload images in markdown file and will replace them.
We found that markdown-img-icexmoon demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.
Security News
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
Security News
In this segment of the Risky Business podcast, Feross Aboukhadijeh and Patrick Gray discuss the challenges of tracking malware discovered in open source softare.