


Small talk on php regular extraction of image address_PHP tutorial
I am obsessed with regular rules and keep trying new tricks. First of all, thanks to TNA for the incomplete output of RSS, and then again to SH for his compulsive learning. Without TNA, I wouldn’t have looked at regular expressions, and I didn’t know there were such awesome expressions in the world. If SH wasn’t just saying that he didn’t understand, I wouldn’t have had the guts to figure it out and improve it. To achieve the same goal, regular expressions may not be unique, and there is nothing that cannot be done, it’s just that you didn’t expect it. You can put it this way, regularity is playing with setting rules. I love this kind of thing. Nothing excites me more and makes me feel awesome than setting rules to filter things.
Share some tips on using regular expressions to extract image addresses in the PHP environment:
The html code of the image URL specification is nothing more than
囧1 and 囧2 are not required. To pass XHTML certification, 囧4, 囧5, and 囧6 are essential. 囧3 is the core content and of course it is indispensable.
As far as regularity is concerned, the shortest match I wrote is
(?<=img.+?src=").*?(? =")
However, this does not work in php, it will appear:
Warning: preg_match_all() [function.preg-match-all]: Compilation failed: lookbehind assertion is not fixed length at offset *** in ***
I have been struggling for a long time, but it doesn’t work. What’s the reason? After trying many times, I finally found that the problem is in the zero-width assertion (?<=img.+?src="). In PHP, zero-width assertions do not support unlimited times like "*" and "+". Something, so an error was reported, just change ".+?" to a fixed length. However, it is basically impossible to fix the length between "img" and "src=". Usually, the img and src of the image address are only. It will be separated by a very simple space, but it does not rule out that in some cases there are alt, titlte and other things before src and after img.
SoYou may ask, simple
You may also ask, clever and short is not enough, I will list the suffix of the picture, it should be ok, such as
RAW http://us.wwe.com/content/media/images/Headers/15559182
SmackDown http://us.wwe.com/content/media/images/Headers/15854138
NXT http://us.wwe.com/content/media/images/Headers/15929136
Superstars http://us.wwe.com/content/media/images/Headers/15815850
What to do? It can still be like this
Different from the above expression, the content of array[0] in this result is not what we want. The image address we want is in array[2]. Why? Because we used 2 (.*?), each "()" thing will automatically exist in a group, and array[0] represents the summary of the results, array[1] contains everything in img and src , array[2] is the turn for the image address we want. This matching method can match not only images with traditional suffixes, but also some image files without suffixes, while not killing other src= files by mistake. Personally, I feel pretty good about it, haha. Of course, if you have any better suggestions, please leave a message immediately, and people around the world will thank you!
What kind of picture do you want? Is it a fixed format or something else? It has to be analyzed in detail.
My suggestion is:
If the format of the image address you want is img space src=, please use: (?<=img.src=").*?(?="), the array is unique, you know.
Otherwise, please use
Let’s talk about php regular extraction of image address
The day before yesterday I wrote a small talk about extracting image addresses using php regular rules, but in fact, extracting the image address in src= is not enough, because there is no guarantee that the address must be an absolute address or a complete address. What if it is relative? If the address is something like:
albums/Candids/thumb_P1050338.jpg
/content/media/touts/5271608/5271654/15320982
What should we do?
Sometimes you need to add http://example1.com/ in front of these addresses, and some even need to add http://example1.com/example2/.../ Therefore, you need to write a rule that meets all the requirements, It’s simply a fantasy. We can only act according to the circumstances and prescribe the right medicine. Sometimes, the knife needs to be cut from the front, sometimes it needs to be cut from the back.
Today, I was surprised to learn something. It turns out that http://example.com/ and http://example.com////// are the same!
http://img3.douban.com/pics/nav/lg_main_a6.png
and
http://img3.douban.com////pics////nav///lg_main_a6.png
Eventually you will arrive
So, if you want to forcibly add a prefix to the two relative addresses mentioned at the beginning to restore them to absolute addresses, it doesn’t matter whether there is a "/" in front of it, just add a "/", "There is a mistake, Didn't let it go." Well, the display will still be normal if there is one more "/", but if there is one less "/", hey, you can't even think about success. I didn't realize this kind of thing at the beginning, so I copied a large section of code and made two copies of the same thing, one with "./." added and one without. I'm from Mars, I'm wasting my time.
Release 2 addresses for public testing of how to obtain images from the webpage:
For any web page, except those that require login: http://xyark.serw5.com/img.php
For Coppermine Photo Gallery system: http://xyark.serw5.com/g.php (if you If you think that the js page that pops up the original image is also needed, I will have to embarrass you)
The general page is an attempt to capture any picture, and the system page is to show what is meant by detailed analysis of specific situations. Those who have tried it will know that the general page does not work for some websites that use the Coppermine Photo Gallery system. What is the reason? It’s that prefix that’s responsible! But the system page can avoid this problem very well.
If you find any bugs during testing, please leave a message to let us know. Please test in a low-key manner, thank you for your cooperation.
Note: The above topics are purely for discussing rules and technology, and cannot be used for illegal purposes. I am not responsible for any cups or tableware that may be damaged due to improper use.
When reprinting, please indicate the original source and author information of the article and this statement in the form of a hyperlink
http://www.blogbus.com/xrspook-logs/85330456.html

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics











PHP is a scripting language widely used on the server side, especially suitable for web development. 1.PHP can embed HTML, process HTTP requests and responses, and supports a variety of databases. 2.PHP is used to generate dynamic web content, process form data, access databases, etc., with strong community support and open source resources. 3. PHP is an interpreted language, and the execution process includes lexical analysis, grammatical analysis, compilation and execution. 4.PHP can be combined with MySQL for advanced applications such as user registration systems. 5. When debugging PHP, you can use functions such as error_reporting() and var_dump(). 6. Optimize PHP code to use caching mechanisms, optimize database queries and use built-in functions. 7

PHP and Python each have their own advantages, and choose according to project requirements. 1.PHP is suitable for web development, especially for rapid development and maintenance of websites. 2. Python is suitable for data science, machine learning and artificial intelligence, with concise syntax and suitable for beginners.

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHP is suitable for web development, with simple syntax and high execution efficiency. 2. Python is suitable for data science and machine learning, with concise syntax and rich libraries.

PHP is widely used in e-commerce, content management systems and API development. 1) E-commerce: used for shopping cart function and payment processing. 2) Content management system: used for dynamic content generation and user management. 3) API development: used for RESTful API development and API security. Through performance optimization and best practices, the efficiency and maintainability of PHP applications are improved.

PHP is still dynamic and still occupies an important position in the field of modern programming. 1) PHP's simplicity and powerful community support make it widely used in web development; 2) Its flexibility and stability make it outstanding in handling web forms, database operations and file processing; 3) PHP is constantly evolving and optimizing, suitable for beginners and experienced developers.

PHP is suitable for web development, especially in rapid development and processing dynamic content, but is not good at data science and enterprise-level applications. Compared with Python, PHP has more advantages in web development, but is not as good as Python in the field of data science; compared with Java, PHP performs worse in enterprise-level applications, but is more flexible in web development; compared with JavaScript, PHP is more concise in back-end development, but is not as good as JavaScript in front-end development.

PHP is mainly procedural programming, but also supports object-oriented programming (OOP); Python supports a variety of paradigms, including OOP, functional and procedural programming. PHP is suitable for web development, and Python is suitable for a variety of applications such as data analysis and machine learning.

PHP and Python have their own advantages and disadvantages, and the choice depends on project needs and personal preferences. 1.PHP is suitable for rapid development and maintenance of large-scale web applications. 2. Python dominates the field of data science and machine learning.
