Home Backend Development PHP Tutorial Small talk on php regular extraction of image address_PHP tutorial

Small talk on php regular extraction of image address_PHP tutorial

Jul 13, 2016 am 10:35 AM
php picture regular

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

Copy code The code is as follows:

囧4

囧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

Copy code The code is as follows:

(?<=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.

So


Copy the code The code is as follows:
(?<=img.src=").*? (?=")

or

Copy code The code is as follows:
(?< ;=imgssrc=").*?(?=")

It may be possible, but there is no guarantee that it will be 100% ok.

You may ask, simple

Copy code The code is as follows:
(?<=src=").*?(?=")

No? Normally, yes, but friends who have searched the page should know that in addition to image addresses starting with src, javascript addresses also start with src! Moreover, there are too many mysterious and unpredictable factors hidden in it, so this seemingly short and perfect writing method will not work.

You may also ask, clever and short is not enough, I will list the suffix of the picture, it should be ok, such as

Copy code The code is as follows:
(?<=src=").*?.(jpg|jpeg| gif|png|bmp|JPG|JPEG|GIF|PNG|BMP)

Indeed, this way of writing is really honest, but have you ever seen pictures without suffixes? wwe.com has many examples of this

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

The URLs above are all pictures, but they don’t have traditional suffixes. It’s no use being honest and you still can’t get them.

What to do? It can still be like this

Copy code The code is as follows:

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

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/746618.htmlTechArticleI am obsessed with regular rules and keep trying new tricks. First of all, thanks to TNA for the non-complete output RSS, and then thanks again to SH compulsive learning. Without TNA, I wouldn’t have watched the regulars, let alone the world...
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

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

Hot Article

Roblox: Bubble Gum Simulator Infinity - How To Get And Use Royal Keys
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers Of The Witch Tree - How To Unlock The Grappling Hook
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Fusion System, Explained
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Hot Topics

Java Tutorial
1667
14
PHP Tutorial
1273
29
C# Tutorial
1255
24
PHP: A Key Language for Web Development PHP: A Key Language for Web Development Apr 13, 2025 am 12:08 AM

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: Comparing Two Popular Programming Languages PHP and Python: Comparing Two Popular Programming Languages Apr 14, 2025 am 12:13 AM

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 vs. Python: Understanding the Differences PHP vs. Python: Understanding the Differences Apr 11, 2025 am 12:15 AM

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 in Action: Real-World Examples and Applications PHP in Action: Real-World Examples and Applications Apr 14, 2025 am 12:19 AM

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.

The Enduring Relevance of PHP: Is It Still Alive? The Enduring Relevance of PHP: Is It Still Alive? Apr 14, 2025 am 12:12 AM

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 vs. Other Languages: A Comparison PHP vs. Other Languages: A Comparison Apr 13, 2025 am 12:19 AM

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 and Python: Different Paradigms Explained PHP and Python: Different Paradigms Explained Apr 18, 2025 am 12:26 AM

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: Code Examples and Comparison PHP and Python: Code Examples and Comparison Apr 15, 2025 am 12:07 AM

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.

See all articles