crawlo 1.4.1__py3-none-any.whl → 1.4.3__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of crawlo might be problematic. Click here for more details.
- crawlo/__init__.py +93 -93
- crawlo/__version__.py +1 -1
- crawlo/cli.py +75 -75
- crawlo/commands/__init__.py +14 -14
- crawlo/commands/check.py +594 -594
- crawlo/commands/genspider.py +151 -151
- crawlo/commands/help.py +138 -138
- crawlo/commands/list.py +155 -155
- crawlo/commands/run.py +341 -341
- crawlo/commands/startproject.py +436 -436
- crawlo/commands/stats.py +187 -187
- crawlo/commands/utils.py +196 -196
- crawlo/config.py +312 -312
- crawlo/config_validator.py +277 -277
- crawlo/core/__init__.py +52 -52
- crawlo/core/engine.py +438 -439
- crawlo/core/processor.py +47 -47
- crawlo/core/scheduler.py +291 -257
- crawlo/crawler.py +650 -650
- crawlo/data/__init__.py +5 -5
- crawlo/data/user_agents.py +194 -194
- crawlo/downloader/__init__.py +273 -273
- crawlo/downloader/aiohttp_downloader.py +233 -228
- crawlo/downloader/cffi_downloader.py +245 -245
- crawlo/downloader/httpx_downloader.py +259 -259
- crawlo/downloader/hybrid_downloader.py +212 -212
- crawlo/downloader/playwright_downloader.py +402 -402
- crawlo/downloader/selenium_downloader.py +472 -472
- crawlo/event.py +11 -11
- crawlo/exceptions.py +81 -81
- crawlo/extension/__init__.py +63 -63
- crawlo/extension/health_check.py +141 -141
- crawlo/extension/log_interval.py +94 -94
- crawlo/extension/log_stats.py +70 -70
- crawlo/extension/logging_extension.py +61 -61
- crawlo/extension/memory_monitor.py +104 -104
- crawlo/extension/performance_profiler.py +133 -133
- crawlo/extension/request_recorder.py +107 -107
- crawlo/factories/__init__.py +27 -27
- crawlo/factories/base.py +68 -68
- crawlo/factories/crawler.py +103 -103
- crawlo/factories/registry.py +84 -84
- crawlo/filters/__init__.py +154 -154
- crawlo/filters/aioredis_filter.py +257 -257
- crawlo/filters/memory_filter.py +269 -269
- crawlo/framework.py +292 -292
- crawlo/initialization/__init__.py +44 -44
- crawlo/initialization/built_in.py +425 -425
- crawlo/initialization/context.py +141 -141
- crawlo/initialization/core.py +193 -193
- crawlo/initialization/phases.py +148 -148
- crawlo/initialization/registry.py +145 -145
- crawlo/items/__init__.py +23 -23
- crawlo/items/base.py +23 -23
- crawlo/items/fields.py +52 -52
- crawlo/items/items.py +104 -104
- crawlo/logging/__init__.py +45 -37
- crawlo/logging/async_handler.py +181 -0
- crawlo/logging/config.py +196 -96
- crawlo/logging/factory.py +171 -128
- crawlo/logging/manager.py +111 -111
- crawlo/logging/monitor.py +153 -0
- crawlo/logging/sampler.py +167 -0
- crawlo/middleware/__init__.py +21 -21
- crawlo/middleware/default_header.py +132 -132
- crawlo/middleware/download_delay.py +104 -104
- crawlo/middleware/middleware_manager.py +135 -135
- crawlo/middleware/offsite.py +123 -123
- crawlo/middleware/proxy.py +386 -386
- crawlo/middleware/request_ignore.py +86 -86
- crawlo/middleware/response_code.py +150 -150
- crawlo/middleware/response_filter.py +136 -136
- crawlo/middleware/retry.py +124 -124
- crawlo/middleware/simple_proxy.py +65 -65
- crawlo/mode_manager.py +219 -219
- crawlo/network/__init__.py +21 -21
- crawlo/network/request.py +379 -379
- crawlo/network/response.py +359 -359
- crawlo/pipelines/__init__.py +21 -21
- crawlo/pipelines/bloom_dedup_pipeline.py +146 -146
- crawlo/pipelines/console_pipeline.py +39 -39
- crawlo/pipelines/csv_pipeline.py +316 -316
- crawlo/pipelines/database_dedup_pipeline.py +197 -197
- crawlo/pipelines/json_pipeline.py +218 -218
- crawlo/pipelines/memory_dedup_pipeline.py +105 -105
- crawlo/pipelines/mongo_pipeline.py +131 -131
- crawlo/pipelines/mysql_pipeline.py +325 -325
- crawlo/pipelines/pipeline_manager.py +100 -84
- crawlo/pipelines/redis_dedup_pipeline.py +156 -156
- crawlo/project.py +349 -338
- crawlo/queue/pqueue.py +42 -42
- crawlo/queue/queue_manager.py +526 -522
- crawlo/queue/redis_priority_queue.py +370 -367
- crawlo/settings/__init__.py +7 -7
- crawlo/settings/default_settings.py +284 -284
- crawlo/settings/setting_manager.py +219 -219
- crawlo/spider/__init__.py +657 -657
- crawlo/stats_collector.py +73 -73
- crawlo/subscriber.py +129 -129
- crawlo/task_manager.py +138 -138
- crawlo/templates/crawlo.cfg.tmpl +10 -10
- crawlo/templates/project/__init__.py.tmpl +3 -3
- crawlo/templates/project/items.py.tmpl +17 -17
- crawlo/templates/project/middlewares.py.tmpl +118 -118
- crawlo/templates/project/pipelines.py.tmpl +96 -96
- crawlo/templates/project/settings.py.tmpl +170 -170
- crawlo/templates/project/settings_distributed.py.tmpl +169 -169
- crawlo/templates/project/settings_gentle.py.tmpl +166 -166
- crawlo/templates/project/settings_high_performance.py.tmpl +167 -167
- crawlo/templates/project/settings_minimal.py.tmpl +65 -65
- crawlo/templates/project/settings_simple.py.tmpl +164 -164
- crawlo/templates/project/spiders/__init__.py.tmpl +9 -9
- crawlo/templates/run.py.tmpl +34 -34
- crawlo/templates/spider/spider.py.tmpl +143 -143
- crawlo/templates/spiders_init.py.tmpl +9 -9
- crawlo/tools/__init__.py +200 -200
- crawlo/tools/anti_crawler.py +268 -268
- crawlo/tools/authenticated_proxy.py +240 -240
- crawlo/tools/data_formatter.py +225 -225
- crawlo/tools/data_validator.py +180 -180
- crawlo/tools/date_tools.py +289 -289
- crawlo/tools/distributed_coordinator.py +384 -384
- crawlo/tools/encoding_converter.py +127 -127
- crawlo/tools/network_diagnostic.py +364 -364
- crawlo/tools/request_tools.py +82 -82
- crawlo/tools/retry_mechanism.py +224 -224
- crawlo/tools/scenario_adapter.py +262 -262
- crawlo/tools/text_cleaner.py +232 -232
- crawlo/utils/__init__.py +34 -34
- crawlo/utils/batch_processor.py +259 -259
- crawlo/utils/class_loader.py +25 -25
- crawlo/utils/controlled_spider_mixin.py +439 -439
- crawlo/utils/db_helper.py +343 -343
- crawlo/utils/enhanced_error_handler.py +356 -356
- crawlo/utils/env_config.py +142 -142
- crawlo/utils/error_handler.py +165 -165
- crawlo/utils/fingerprint.py +122 -122
- crawlo/utils/func_tools.py +82 -82
- crawlo/utils/large_scale_config.py +286 -286
- crawlo/utils/large_scale_helper.py +344 -344
- crawlo/utils/log.py +79 -79
- crawlo/utils/performance_monitor.py +285 -285
- crawlo/utils/queue_helper.py +175 -175
- crawlo/utils/redis_connection_pool.py +388 -388
- crawlo/utils/redis_key_validator.py +198 -198
- crawlo/utils/request.py +267 -267
- crawlo/utils/request_serializer.py +225 -225
- crawlo/utils/spider_loader.py +61 -61
- crawlo/utils/system.py +11 -11
- crawlo/utils/tools.py +4 -4
- crawlo/utils/url.py +39 -39
- crawlo-1.4.3.dist-info/METADATA +190 -0
- crawlo-1.4.3.dist-info/RECORD +326 -0
- examples/__init__.py +7 -7
- examples/test_project/__init__.py +7 -7
- examples/test_project/run.py +34 -34
- examples/test_project/test_project/__init__.py +3 -3
- examples/test_project/test_project/items.py +17 -17
- examples/test_project/test_project/middlewares.py +118 -118
- examples/test_project/test_project/pipelines.py +96 -96
- examples/test_project/test_project/settings.py +169 -169
- examples/test_project/test_project/spiders/__init__.py +9 -9
- examples/test_project/test_project/spiders/of_week_dis.py +143 -143
- tests/__init__.py +7 -7
- tests/advanced_tools_example.py +275 -275
- tests/authenticated_proxy_example.py +106 -106
- tests/baidu_performance_test.py +108 -108
- tests/baidu_test.py +59 -59
- tests/cleaners_example.py +160 -160
- tests/comprehensive_framework_test.py +212 -212
- tests/comprehensive_test.py +81 -81
- tests/comprehensive_testing_summary.md +186 -186
- tests/config_validation_demo.py +142 -142
- tests/controlled_spider_example.py +205 -205
- tests/date_tools_example.py +180 -180
- tests/debug_configure.py +69 -69
- tests/debug_framework_logger.py +84 -84
- tests/debug_log_config.py +126 -126
- tests/debug_log_levels.py +63 -63
- tests/debug_pipelines.py +66 -66
- tests/detailed_log_test.py +233 -233
- tests/distributed_test.py +66 -66
- tests/distributed_test_debug.py +76 -76
- tests/dynamic_loading_example.py +523 -523
- tests/dynamic_loading_test.py +104 -104
- tests/env_config_example.py +133 -133
- tests/error_handling_example.py +171 -171
- tests/final_comprehensive_test.py +151 -151
- tests/final_log_test.py +260 -260
- tests/final_validation_test.py +182 -182
- tests/fix_log_test.py +142 -142
- tests/framework_performance_test.py +202 -202
- tests/log_buffering_test.py +111 -111
- tests/log_generation_timing_test.py +153 -153
- tests/optimized_performance_test.py +211 -211
- tests/performance_comparison.py +245 -245
- tests/queue_blocking_test.py +113 -113
- tests/queue_test.py +89 -89
- tests/redis_key_validation_demo.py +130 -130
- tests/request_params_example.py +150 -150
- tests/response_improvements_example.py +144 -144
- tests/scrapy_comparison/ofweek_scrapy.py +138 -138
- tests/scrapy_comparison/scrapy_test.py +133 -133
- tests/simple_command_test.py +119 -119
- tests/simple_crawlo_test.py +127 -127
- tests/simple_log_test.py +57 -57
- tests/simple_log_test2.py +137 -137
- tests/simple_optimization_test.py +128 -128
- tests/simple_queue_type_test.py +41 -41
- tests/simple_spider_test.py +49 -49
- tests/simple_test.py +47 -47
- tests/spider_log_timing_test.py +177 -177
- tests/test_advanced_tools.py +148 -148
- tests/test_all_commands.py +230 -230
- tests/test_all_pipeline_fingerprints.py +133 -133
- tests/test_all_redis_key_configs.py +145 -145
- tests/test_authenticated_proxy.py +141 -141
- tests/test_batch_processor.py +178 -178
- tests/test_cleaners.py +54 -54
- tests/test_component_factory.py +174 -174
- tests/test_comprehensive.py +146 -146
- tests/test_config_consistency.py +80 -80
- tests/test_config_merge.py +152 -152
- tests/test_config_validator.py +182 -182
- tests/test_controlled_spider_mixin.py +79 -79
- tests/test_crawlo_proxy_integration.py +108 -108
- tests/test_date_tools.py +123 -123
- tests/test_dedup_fix.py +220 -220
- tests/test_dedup_pipeline_consistency.py +125 -0
- tests/test_default_header_middleware.py +313 -313
- tests/test_distributed.py +65 -65
- tests/test_double_crawlo_fix.py +204 -204
- tests/test_double_crawlo_fix_simple.py +124 -124
- tests/test_download_delay_middleware.py +221 -221
- tests/test_downloader_proxy_compatibility.py +268 -268
- tests/test_dynamic_downloaders_proxy.py +124 -124
- tests/test_dynamic_proxy.py +92 -92
- tests/test_dynamic_proxy_config.py +146 -146
- tests/test_dynamic_proxy_real.py +109 -109
- tests/test_edge_cases.py +303 -303
- tests/test_enhanced_error_handler.py +270 -270
- tests/test_enhanced_error_handler_comprehensive.py +245 -245
- tests/test_env_config.py +121 -121
- tests/test_error_handler_compatibility.py +112 -112
- tests/test_factories.py +252 -252
- tests/test_final_validation.py +153 -153
- tests/test_fingerprint_consistency.py +135 -135
- tests/test_fingerprint_simple.py +51 -51
- tests/test_framework_env_usage.py +103 -103
- tests/test_framework_logger.py +66 -66
- tests/test_framework_startup.py +64 -64
- tests/test_get_component_logger.py +83 -83
- tests/test_hash_performance.py +99 -99
- tests/test_integration.py +169 -169
- tests/test_item_dedup_redis_key.py +122 -122
- tests/test_large_scale_config.py +112 -112
- tests/test_large_scale_helper.py +235 -235
- tests/test_logging_enhancements.py +375 -0
- tests/test_logging_final.py +185 -0
- tests/test_logging_integration.py +313 -0
- tests/test_logging_system.py +282 -282
- tests/test_middleware_debug.py +142 -0
- tests/test_mode_change.py +72 -72
- tests/test_mode_consistency.py +51 -51
- tests/test_offsite_middleware.py +244 -244
- tests/test_offsite_middleware_simple.py +203 -203
- tests/test_parsel.py +29 -29
- tests/test_performance.py +327 -327
- tests/test_performance_monitor.py +115 -115
- tests/test_pipeline_fingerprint_consistency.py +86 -86
- tests/test_priority_behavior.py +212 -0
- tests/test_priority_consistency.py +152 -0
- tests/test_priority_consistency_fixed.py +250 -0
- tests/test_proxy_api.py +264 -264
- tests/test_proxy_health_check.py +32 -32
- tests/test_proxy_middleware.py +121 -121
- tests/test_proxy_middleware_enhanced.py +216 -216
- tests/test_proxy_middleware_integration.py +136 -136
- tests/test_proxy_middleware_refactored.py +184 -184
- tests/test_proxy_providers.py +56 -56
- tests/test_proxy_stats.py +19 -19
- tests/test_proxy_strategies.py +59 -59
- tests/test_queue_empty_check.py +41 -41
- tests/test_queue_manager_double_crawlo.py +173 -173
- tests/test_queue_manager_redis_key.py +179 -179
- tests/test_queue_naming.py +154 -154
- tests/test_queue_type.py +106 -106
- tests/test_queue_type_redis_config_consistency.py +131 -0
- tests/test_random_headers_default.py +323 -0
- tests/test_random_headers_necessity.py +309 -0
- tests/test_random_user_agent.py +72 -72
- tests/test_real_scenario_proxy.py +195 -195
- tests/test_redis_config.py +28 -28
- tests/test_redis_connection_pool.py +294 -294
- tests/test_redis_key_naming.py +181 -181
- tests/test_redis_key_validator.py +123 -123
- tests/test_redis_queue.py +224 -224
- tests/test_redis_queue_name_fix.py +175 -175
- tests/test_redis_queue_type_fallback.py +130 -0
- tests/test_request_ignore_middleware.py +182 -182
- tests/test_request_params.py +111 -111
- tests/test_request_serialization.py +70 -70
- tests/test_response_code_middleware.py +349 -349
- tests/test_response_filter_middleware.py +427 -427
- tests/test_response_improvements.py +152 -152
- tests/test_retry_middleware.py +334 -242
- tests/test_retry_middleware_realistic.py +274 -0
- tests/test_scheduler.py +252 -252
- tests/test_scheduler_config_update.py +133 -133
- tests/test_simple_response.py +61 -61
- tests/test_telecom_spider_redis_key.py +205 -205
- tests/test_template_content.py +87 -87
- tests/test_template_redis_key.py +134 -134
- tests/test_tools.py +159 -159
- tests/test_user_agent_randomness.py +177 -0
- tests/test_user_agents.py +96 -96
- tests/tools_example.py +260 -260
- tests/untested_features_report.md +138 -138
- tests/verify_debug.py +51 -51
- tests/verify_distributed.py +117 -117
- tests/verify_log_fix.py +111 -111
- crawlo-1.4.1.dist-info/METADATA +0 -1199
- crawlo-1.4.1.dist-info/RECORD +0 -309
- {crawlo-1.4.1.dist-info → crawlo-1.4.3.dist-info}/WHEEL +0 -0
- {crawlo-1.4.1.dist-info → crawlo-1.4.3.dist-info}/entry_points.txt +0 -0
- {crawlo-1.4.1.dist-info → crawlo-1.4.3.dist-info}/top_level.txt +0 -0
tests/test_random_user_agent.py
CHANGED
|
@@ -1,73 +1,73 @@
|
|
|
1
|
-
#!/usr/bin/env python
|
|
2
|
-
# -*- coding: utf-8 -*-
|
|
3
|
-
"""
|
|
4
|
-
测试随机User-Agent功能
|
|
5
|
-
"""
|
|
6
|
-
|
|
7
|
-
import sys
|
|
8
|
-
import os
|
|
9
|
-
|
|
10
|
-
# 添加项目根目录到Python路径
|
|
11
|
-
sys.path.insert(0, os.path.join(os.path.dirname(__file__), '..'))
|
|
12
|
-
|
|
13
|
-
from crawlo.data.user_agents import get_random_user_agent
|
|
14
|
-
from crawlo.middleware.default_header import DefaultHeaderMiddleware
|
|
15
|
-
from crawlo.settings.setting_manager import SettingManager
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
def test_random_user_agent_function():
|
|
19
|
-
"""测试随机User-Agent函数"""
|
|
20
|
-
print("=== 随机User-Agent函数测试 ===")
|
|
21
|
-
|
|
22
|
-
# 测试各种设备类型的随机User-Agent
|
|
23
|
-
device_types = ["desktop", "mobile", "all", "chrome", "firefox", "safari", "edge", "opera"]
|
|
24
|
-
|
|
25
|
-
for device_type in device_types:
|
|
26
|
-
print(f"\n{device_type}类型随机User-Agent:")
|
|
27
|
-
for i in range(3):
|
|
28
|
-
ua = get_random_user_agent(device_type)
|
|
29
|
-
print(f" {i+1}. {ua}")
|
|
30
|
-
|
|
31
|
-
print()
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
def test_default_header_middleware_with_random_ua():
|
|
35
|
-
"""测试DefaultHeaderMiddleware与随机User-Agent"""
|
|
36
|
-
print("=== DefaultHeaderMiddleware与随机User-Agent测试 ===")
|
|
37
|
-
|
|
38
|
-
# 创建设置管理器
|
|
39
|
-
settings = SettingManager()
|
|
40
|
-
settings.set("LOG_LEVEL", "INFO")
|
|
41
|
-
settings.set("RANDOM_USER_AGENT_ENABLED", True)
|
|
42
|
-
settings.set("USER_AGENT_DEVICE_TYPE", "all")
|
|
43
|
-
# 添加一个默认请求头以启用中间件
|
|
44
|
-
settings.set("DEFAULT_REQUEST_HEADERS", {"Accept": "text/html"})
|
|
45
|
-
|
|
46
|
-
# 创建中间件实例
|
|
47
|
-
middleware = DefaultHeaderMiddleware(settings, "INFO")
|
|
48
|
-
|
|
49
|
-
print(f"随机User-Agent功能已启用: {middleware.random_user_agent_enabled}")
|
|
50
|
-
print(f"User-Agent设备类型: {middleware.user_agent_device_type}")
|
|
51
|
-
print(f"内置User-Agent列表数量: {len(middleware.user_agents)}")
|
|
52
|
-
|
|
53
|
-
# 测试获取随机User-Agent
|
|
54
|
-
print("\n随机User-Agent测试:")
|
|
55
|
-
for i in range(5):
|
|
56
|
-
random_ua = middleware._get_random_user_agent()
|
|
57
|
-
print(f" {i+1}. {random_ua}")
|
|
58
|
-
|
|
59
|
-
print()
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
def main():
|
|
63
|
-
"""主测试函数"""
|
|
64
|
-
print("开始测试随机User-Agent功能...\n")
|
|
65
|
-
|
|
66
|
-
test_random_user_agent_function()
|
|
67
|
-
test_default_header_middleware_with_random_ua()
|
|
68
|
-
|
|
69
|
-
print("所有测试完成!")
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
if __name__ == "__main__":
|
|
1
|
+
#!/usr/bin/env python
|
|
2
|
+
# -*- coding: utf-8 -*-
|
|
3
|
+
"""
|
|
4
|
+
测试随机User-Agent功能
|
|
5
|
+
"""
|
|
6
|
+
|
|
7
|
+
import sys
|
|
8
|
+
import os
|
|
9
|
+
|
|
10
|
+
# 添加项目根目录到Python路径
|
|
11
|
+
sys.path.insert(0, os.path.join(os.path.dirname(__file__), '..'))
|
|
12
|
+
|
|
13
|
+
from crawlo.data.user_agents import get_random_user_agent
|
|
14
|
+
from crawlo.middleware.default_header import DefaultHeaderMiddleware
|
|
15
|
+
from crawlo.settings.setting_manager import SettingManager
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
def test_random_user_agent_function():
|
|
19
|
+
"""测试随机User-Agent函数"""
|
|
20
|
+
print("=== 随机User-Agent函数测试 ===")
|
|
21
|
+
|
|
22
|
+
# 测试各种设备类型的随机User-Agent
|
|
23
|
+
device_types = ["desktop", "mobile", "all", "chrome", "firefox", "safari", "edge", "opera"]
|
|
24
|
+
|
|
25
|
+
for device_type in device_types:
|
|
26
|
+
print(f"\n{device_type}类型随机User-Agent:")
|
|
27
|
+
for i in range(3):
|
|
28
|
+
ua = get_random_user_agent(device_type)
|
|
29
|
+
print(f" {i+1}. {ua}")
|
|
30
|
+
|
|
31
|
+
print()
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
def test_default_header_middleware_with_random_ua():
|
|
35
|
+
"""测试DefaultHeaderMiddleware与随机User-Agent"""
|
|
36
|
+
print("=== DefaultHeaderMiddleware与随机User-Agent测试 ===")
|
|
37
|
+
|
|
38
|
+
# 创建设置管理器
|
|
39
|
+
settings = SettingManager()
|
|
40
|
+
settings.set("LOG_LEVEL", "INFO")
|
|
41
|
+
settings.set("RANDOM_USER_AGENT_ENABLED", True)
|
|
42
|
+
settings.set("USER_AGENT_DEVICE_TYPE", "all")
|
|
43
|
+
# 添加一个默认请求头以启用中间件
|
|
44
|
+
settings.set("DEFAULT_REQUEST_HEADERS", {"Accept": "text/html"})
|
|
45
|
+
|
|
46
|
+
# 创建中间件实例
|
|
47
|
+
middleware = DefaultHeaderMiddleware(settings, "INFO")
|
|
48
|
+
|
|
49
|
+
print(f"随机User-Agent功能已启用: {middleware.random_user_agent_enabled}")
|
|
50
|
+
print(f"User-Agent设备类型: {middleware.user_agent_device_type}")
|
|
51
|
+
print(f"内置User-Agent列表数量: {len(middleware.user_agents)}")
|
|
52
|
+
|
|
53
|
+
# 测试获取随机User-Agent
|
|
54
|
+
print("\n随机User-Agent测试:")
|
|
55
|
+
for i in range(5):
|
|
56
|
+
random_ua = middleware._get_random_user_agent()
|
|
57
|
+
print(f" {i+1}. {random_ua}")
|
|
58
|
+
|
|
59
|
+
print()
|
|
60
|
+
|
|
61
|
+
|
|
62
|
+
def main():
|
|
63
|
+
"""主测试函数"""
|
|
64
|
+
print("开始测试随机User-Agent功能...\n")
|
|
65
|
+
|
|
66
|
+
test_random_user_agent_function()
|
|
67
|
+
test_default_header_middleware_with_random_ua()
|
|
68
|
+
|
|
69
|
+
print("所有测试完成!")
|
|
70
|
+
|
|
71
|
+
|
|
72
|
+
if __name__ == "__main__":
|
|
73
73
|
main()
|
|
@@ -1,196 +1,196 @@
|
|
|
1
|
-
#!/usr/bin/python
|
|
2
|
-
# -*- coding: UTF-8 -*-
|
|
3
|
-
"""
|
|
4
|
-
真实场景代理测试
|
|
5
|
-
================
|
|
6
|
-
使用用户提供的headers、cookies和URL测试代理功能
|
|
7
|
-
"""
|
|
8
|
-
|
|
9
|
-
import asyncio
|
|
10
|
-
import aiohttp
|
|
11
|
-
import sys
|
|
12
|
-
import os
|
|
13
|
-
from urllib.parse import urlparse
|
|
14
|
-
|
|
15
|
-
# 添加项目根目录到Python路径
|
|
16
|
-
sys.path.insert(0, os.path.join(os.path.dirname(__file__), '..'))
|
|
17
|
-
|
|
18
|
-
# 用户提供的请求头
|
|
19
|
-
HEADERS = {
|
|
20
|
-
"accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7",
|
|
21
|
-
"accept-language": "zh-CN,zh;q=0.9,en;q=0.8",
|
|
22
|
-
"cache-control": "no-cache",
|
|
23
|
-
"pragma": "no-cache",
|
|
24
|
-
"priority": "u=0, i",
|
|
25
|
-
"sec-ch-ua": "\"Chromium\";v=\"140\", \"Not=A?Brand\";v=\"24\", \"Google Chrome\";v=\"140\"",
|
|
26
|
-
"sec-ch-ua-mobile": "?0",
|
|
27
|
-
"sec-ch-ua-platform": "\"Windows\"",
|
|
28
|
-
"sec-fetch-dest": "document",
|
|
29
|
-
"sec-fetch-mode": "navigate",
|
|
30
|
-
"sec-fetch-site": "none",
|
|
31
|
-
"sec-fetch-user": "?1",
|
|
32
|
-
"upgrade-insecure-requests": "1",
|
|
33
|
-
"user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/140.0.0.0 Safari/537.36"
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
# 用户提供的cookies
|
|
37
|
-
COOKIES = {
|
|
38
|
-
"Hm_lvt_722143063e4892925903024537075d0d": "1758071793",
|
|
39
|
-
"Hm_lvt_929f8b362150b1f77b477230541dbbc2": "1758071793",
|
|
40
|
-
"historystock": "600699",
|
|
41
|
-
"spversion": "20130314",
|
|
42
|
-
"cid": "f9bc812da2c3a7ddf6d5df1fa2d497091758076438",
|
|
43
|
-
"u_ukey": "A10702B8689642C6BE607730E11E6E4A",
|
|
44
|
-
"u_uver": "1.0.0",
|
|
45
|
-
"u_dpass": "Qk3U07X7SHGKa0AcRUg1R1DVWbPioD9Eg270bdikvlwWWXexbsXnRsQNt%2B04iXwdHi80LrSsTFH9a%2B6rtRvqGg%3D%3D",
|
|
46
|
-
"u_did": "E3ED337393E1429DA56E380DD00B3CCD",
|
|
47
|
-
"u_ttype": "WEB",
|
|
48
|
-
"user_status": "0",
|
|
49
|
-
"ttype": "WEB",
|
|
50
|
-
"log": "",
|
|
51
|
-
"Hm_lvt_69929b9dce4c22a060bd22d703b2a280": "1758079404,1758113068,1758157144",
|
|
52
|
-
"HMACCOUNT": "08DF0D235A291EAA",
|
|
53
|
-
"Hm_lvt_78c58f01938e4d85eaf619eae71b4ed1": "1758071793,1758113068,1758157144",
|
|
54
|
-
"user": "MDpteF9lNXRkY3RpdHo6Ok5vbmU6NTAwOjgxNzYyOTAwNDo3LDExMTExMTExMTExLDQwOzQ0LDExLDQwOzYsMSw0MDs1LDEsNDA7MSwxMDEsNDA7MiwxLDQwOzMsMSw0MDs1LDEsNDA7OCwwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMSw0MDsxMDIsMSw0MDoxNjo6OjgwNzYyOTAwNDoxNzU4MTYxNTE0Ojo6MTc1ODA3MjA2MDo2MDQ4MDA6MDoxYTQ0NmFlNDY4M2VmZWY3YmNjYTczY2U3ODZmZTNiODg6ZGVmYXVsdF81OjA%3D",
|
|
55
|
-
"userid": "807629004",
|
|
56
|
-
"u_name": "mx_e5tdctitz",
|
|
57
|
-
"escapename": "mx_e5tdctitz",
|
|
58
|
-
"ticket": "85eea709becdd924d7eb975351de629e",
|
|
59
|
-
"utk": "8959c4c6b6f5fb7628864feab15473f4",
|
|
60
|
-
"sess_tk": "eyJ0eXAiOiJKV1QiLCJhbGciOiJFUzI1NiIsImtpZCI6InNlc3NfdGtfMSIsImJ0eSI6InNlc3NfdGsifQ.eyJqdGkiOiI4ODNiZmU4NmU3M2NhN2NjN2JlZmVmODM0NmFlNDZhNDEiLCJpYXQiOjE3NTgxNjE1MTQsImV4cCI6MTc1ODc2NjMxNCwic3ViIjoiODA3NjI5MDA0IiwiaXNzIjoidXBhc3MuaXdlbmNhaS5jb20iLCJhdWQiOiIyMDIwMTExODUyODg5MDcyIiwiYWN0Ijoib2ZjIiwiY3VocyI6ImIwNTcyZDVjOWNlNDg0MGFlOWYxYTlhYjU3NGZkNjQyYjgzNmExN2E3Y2NhZjk4ZWRiNzI5ZmJkOWFjOGVkYmYifQ.UBNIzxGvQQtXSiIcB_1JJl-EuAc1S9j2LcTLXjwy4ImhDDbh1oJvyRdDUrXdUpwBpIyx5zgYqgt_3FEhY_iayw",
|
|
61
|
-
"cuc": "ap2eap3gg99g",
|
|
62
|
-
"Hm_lvt_f79b64788a4e377c608617fba4c736e2": "1758161692",
|
|
63
|
-
"v": "A1glI4rWhPCQGqh0MvA0ioufKY3vQbzLHqWQT5JJpBNGLfazOlGMW261YNrh",
|
|
64
|
-
"Hm_lpvt_78c58f01938e4d85eaf619eae71b4ed1": "1758163145",
|
|
65
|
-
"Hm_lpvt_f79b64788a4e377c608617fba4c736e2": "1758163145",
|
|
66
|
-
"Hm_lpvt_69929b9dce4c22a060bd22d703b2a280": "1758163145"
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
# 用户提供的URL
|
|
70
|
-
URL = "https://stock.10jqka.com.cn/20240315/c655957791.shtml"
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
async def test_without_proxy():
|
|
74
|
-
"""不使用代理直接测试访问"""
|
|
75
|
-
print("=== 不使用代理直接访问 ===")
|
|
76
|
-
print(f"URL: {URL}")
|
|
77
|
-
|
|
78
|
-
try:
|
|
79
|
-
timeout = aiohttp.ClientTimeout(total=15)
|
|
80
|
-
async with aiohttp.ClientSession(timeout=timeout, headers=HEADERS, cookies=COOKIES) as session:
|
|
81
|
-
async with session.get(URL) as response:
|
|
82
|
-
print(f"状态码: {response.status}")
|
|
83
|
-
if response.status == 200:
|
|
84
|
-
print("直接访问成功")
|
|
85
|
-
return True
|
|
86
|
-
else:
|
|
87
|
-
print(f"直接访问失败,状态码: {response.status}")
|
|
88
|
-
return False
|
|
89
|
-
except Exception as e:
|
|
90
|
-
print(f"直接访问出错: {e}")
|
|
91
|
-
return False
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
async def test_with_proxy(proxy_url):
|
|
95
|
-
"""使用代理测试访问"""
|
|
96
|
-
print(f"\n=== 使用代理访问 ===")
|
|
97
|
-
print(f"代理地址: {proxy_url}")
|
|
98
|
-
print(f"URL: {URL}")
|
|
99
|
-
|
|
100
|
-
try:
|
|
101
|
-
timeout = aiohttp.ClientTimeout(total=15)
|
|
102
|
-
async with aiohttp.ClientSession(timeout=timeout, headers=HEADERS, cookies=COOKIES) as session:
|
|
103
|
-
# 处理带认证的代理
|
|
104
|
-
if "@" in proxy_url and "://" in proxy_url:
|
|
105
|
-
parsed = urlparse(proxy_url)
|
|
106
|
-
if parsed.username and parsed.password:
|
|
107
|
-
# 提取认证信息
|
|
108
|
-
auth = aiohttp.BasicAuth(parsed.username, parsed.password)
|
|
109
|
-
# 清理代理URL
|
|
110
|
-
clean_proxy = f"{parsed.scheme}://{parsed.hostname}"
|
|
111
|
-
if parsed.port:
|
|
112
|
-
clean_proxy += f":{parsed.port}"
|
|
113
|
-
|
|
114
|
-
print(f"使用带认证的代理: {clean_proxy}")
|
|
115
|
-
async with session.get(URL, proxy=clean_proxy, proxy_auth=auth) as response:
|
|
116
|
-
print(f"状态码: {response.status}")
|
|
117
|
-
if response.status == 200:
|
|
118
|
-
print("代理访问成功")
|
|
119
|
-
return True
|
|
120
|
-
else:
|
|
121
|
-
print(f"代理访问失败,状态码: {response.status}")
|
|
122
|
-
return False
|
|
123
|
-
else:
|
|
124
|
-
# 直接使用代理URL
|
|
125
|
-
print(f"使用代理: {proxy_url}")
|
|
126
|
-
async with session.get(URL, proxy=proxy_url) as response:
|
|
127
|
-
print(f"状态码: {response.status}")
|
|
128
|
-
if response.status == 200:
|
|
129
|
-
print("代理访问成功")
|
|
130
|
-
return True
|
|
131
|
-
else:
|
|
132
|
-
print(f"代理访问失败,状态码: {response.status}")
|
|
133
|
-
return False
|
|
134
|
-
except Exception as e:
|
|
135
|
-
print(f"代理访问出错: {e}")
|
|
136
|
-
return False
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
async def get_proxy_from_api():
|
|
140
|
-
"""从代理API获取代理"""
|
|
141
|
-
proxy_api = 'http://test.proxy.api:8080/proxy/getitem/'
|
|
142
|
-
print(f"\n=== 从代理API获取代理 ===")
|
|
143
|
-
print(f"API地址: {proxy_api}")
|
|
144
|
-
|
|
145
|
-
try:
|
|
146
|
-
timeout = aiohttp.ClientTimeout(total=10)
|
|
147
|
-
async with aiohttp.ClientSession(timeout=timeout) as session:
|
|
148
|
-
async with session.get(proxy_api) as response:
|
|
149
|
-
print(f"状态码: {response.status}")
|
|
150
|
-
|
|
151
|
-
if response.status == 200:
|
|
152
|
-
data = await response.json()
|
|
153
|
-
print(f"响应数据: {data}")
|
|
154
|
-
|
|
155
|
-
# 提取代理URL
|
|
156
|
-
if isinstance(data, dict) and data.get('status') == 0:
|
|
157
|
-
proxy_info = data.get('proxy', {})
|
|
158
|
-
if isinstance(proxy_info, dict):
|
|
159
|
-
proxy_url = proxy_info.get('https') or proxy_info.get('http')
|
|
160
|
-
if proxy_url:
|
|
161
|
-
print(f"提取到的代理URL: {proxy_url}")
|
|
162
|
-
return proxy_url
|
|
163
|
-
print("无法获取代理URL")
|
|
164
|
-
return None
|
|
165
|
-
except Exception as e:
|
|
166
|
-
print(f"API请求出错: {e}")
|
|
167
|
-
return None
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
async def main():
|
|
171
|
-
"""主测试函数"""
|
|
172
|
-
print("开始真实场景代理测试...")
|
|
173
|
-
print("=" * 50)
|
|
174
|
-
|
|
175
|
-
# 1. 首先测试不使用代理直接访问
|
|
176
|
-
direct_success = await test_without_proxy()
|
|
177
|
-
|
|
178
|
-
# 2. 从代理API获取代理
|
|
179
|
-
proxy_url = await get_proxy_from_api()
|
|
180
|
-
|
|
181
|
-
if not proxy_url:
|
|
182
|
-
print("\n无法获取代理,测试结束")
|
|
183
|
-
return
|
|
184
|
-
|
|
185
|
-
# 3. 使用代理访问
|
|
186
|
-
proxy_success = await test_with_proxy(proxy_url)
|
|
187
|
-
|
|
188
|
-
# 4. 测试结果总结
|
|
189
|
-
print(f"\n{'='*30}")
|
|
190
|
-
print("测试结果:")
|
|
191
|
-
print(f"直接访问: {'成功' if direct_success else '失败'}")
|
|
192
|
-
print(f"代理访问: {'成功' if proxy_success else '失败'}")
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
if __name__ == "__main__":
|
|
1
|
+
#!/usr/bin/python
|
|
2
|
+
# -*- coding: UTF-8 -*-
|
|
3
|
+
"""
|
|
4
|
+
真实场景代理测试
|
|
5
|
+
================
|
|
6
|
+
使用用户提供的headers、cookies和URL测试代理功能
|
|
7
|
+
"""
|
|
8
|
+
|
|
9
|
+
import asyncio
|
|
10
|
+
import aiohttp
|
|
11
|
+
import sys
|
|
12
|
+
import os
|
|
13
|
+
from urllib.parse import urlparse
|
|
14
|
+
|
|
15
|
+
# 添加项目根目录到Python路径
|
|
16
|
+
sys.path.insert(0, os.path.join(os.path.dirname(__file__), '..'))
|
|
17
|
+
|
|
18
|
+
# 用户提供的请求头
|
|
19
|
+
HEADERS = {
|
|
20
|
+
"accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7",
|
|
21
|
+
"accept-language": "zh-CN,zh;q=0.9,en;q=0.8",
|
|
22
|
+
"cache-control": "no-cache",
|
|
23
|
+
"pragma": "no-cache",
|
|
24
|
+
"priority": "u=0, i",
|
|
25
|
+
"sec-ch-ua": "\"Chromium\";v=\"140\", \"Not=A?Brand\";v=\"24\", \"Google Chrome\";v=\"140\"",
|
|
26
|
+
"sec-ch-ua-mobile": "?0",
|
|
27
|
+
"sec-ch-ua-platform": "\"Windows\"",
|
|
28
|
+
"sec-fetch-dest": "document",
|
|
29
|
+
"sec-fetch-mode": "navigate",
|
|
30
|
+
"sec-fetch-site": "none",
|
|
31
|
+
"sec-fetch-user": "?1",
|
|
32
|
+
"upgrade-insecure-requests": "1",
|
|
33
|
+
"user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/140.0.0.0 Safari/537.36"
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
# 用户提供的cookies
|
|
37
|
+
COOKIES = {
|
|
38
|
+
"Hm_lvt_722143063e4892925903024537075d0d": "1758071793",
|
|
39
|
+
"Hm_lvt_929f8b362150b1f77b477230541dbbc2": "1758071793",
|
|
40
|
+
"historystock": "600699",
|
|
41
|
+
"spversion": "20130314",
|
|
42
|
+
"cid": "f9bc812da2c3a7ddf6d5df1fa2d497091758076438",
|
|
43
|
+
"u_ukey": "A10702B8689642C6BE607730E11E6E4A",
|
|
44
|
+
"u_uver": "1.0.0",
|
|
45
|
+
"u_dpass": "Qk3U07X7SHGKa0AcRUg1R1DVWbPioD9Eg270bdikvlwWWXexbsXnRsQNt%2B04iXwdHi80LrSsTFH9a%2B6rtRvqGg%3D%3D",
|
|
46
|
+
"u_did": "E3ED337393E1429DA56E380DD00B3CCD",
|
|
47
|
+
"u_ttype": "WEB",
|
|
48
|
+
"user_status": "0",
|
|
49
|
+
"ttype": "WEB",
|
|
50
|
+
"log": "",
|
|
51
|
+
"Hm_lvt_69929b9dce4c22a060bd22d703b2a280": "1758079404,1758113068,1758157144",
|
|
52
|
+
"HMACCOUNT": "08DF0D235A291EAA",
|
|
53
|
+
"Hm_lvt_78c58f01938e4d85eaf619eae71b4ed1": "1758071793,1758113068,1758157144",
|
|
54
|
+
"user": "MDpteF9lNXRkY3RpdHo6Ok5vbmU6NTAwOjgxNzYyOTAwNDo3LDExMTExMTExMTExLDQwOzQ0LDExLDQwOzYsMSw0MDs1LDEsNDA7MSwxMDEsNDA7MiwxLDQwOzMsMSw0MDs1LDEsNDA7OCwwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMSw0MDsxMDIsMSw0MDoxNjo6OjgwNzYyOTAwNDoxNzU4MTYxNTE0Ojo6MTc1ODA3MjA2MDo2MDQ4MDA6MDoxYTQ0NmFlNDY4M2VmZWY3YmNjYTczY2U3ODZmZTNiODg6ZGVmYXVsdF81OjA%3D",
|
|
55
|
+
"userid": "807629004",
|
|
56
|
+
"u_name": "mx_e5tdctitz",
|
|
57
|
+
"escapename": "mx_e5tdctitz",
|
|
58
|
+
"ticket": "85eea709becdd924d7eb975351de629e",
|
|
59
|
+
"utk": "8959c4c6b6f5fb7628864feab15473f4",
|
|
60
|
+
"sess_tk": "eyJ0eXAiOiJKV1QiLCJhbGciOiJFUzI1NiIsImtpZCI6InNlc3NfdGtfMSIsImJ0eSI6InNlc3NfdGsifQ.eyJqdGkiOiI4ODNiZmU4NmU3M2NhN2NjN2JlZmVmODM0NmFlNDZhNDEiLCJpYXQiOjE3NTgxNjE1MTQsImV4cCI6MTc1ODc2NjMxNCwic3ViIjoiODA3NjI5MDA0IiwiaXNzIjoidXBhc3MuaXdlbmNhaS5jb20iLCJhdWQiOiIyMDIwMTExODUyODg5MDcyIiwiYWN0Ijoib2ZjIiwiY3VocyI6ImIwNTcyZDVjOWNlNDg0MGFlOWYxYTlhYjU3NGZkNjQyYjgzNmExN2E3Y2NhZjk4ZWRiNzI5ZmJkOWFjOGVkYmYifQ.UBNIzxGvQQtXSiIcB_1JJl-EuAc1S9j2LcTLXjwy4ImhDDbh1oJvyRdDUrXdUpwBpIyx5zgYqgt_3FEhY_iayw",
|
|
61
|
+
"cuc": "ap2eap3gg99g",
|
|
62
|
+
"Hm_lvt_f79b64788a4e377c608617fba4c736e2": "1758161692",
|
|
63
|
+
"v": "A1glI4rWhPCQGqh0MvA0ioufKY3vQbzLHqWQT5JJpBNGLfazOlGMW261YNrh",
|
|
64
|
+
"Hm_lpvt_78c58f01938e4d85eaf619eae71b4ed1": "1758163145",
|
|
65
|
+
"Hm_lpvt_f79b64788a4e377c608617fba4c736e2": "1758163145",
|
|
66
|
+
"Hm_lpvt_69929b9dce4c22a060bd22d703b2a280": "1758163145"
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
# 用户提供的URL
|
|
70
|
+
URL = "https://stock.10jqka.com.cn/20240315/c655957791.shtml"
|
|
71
|
+
|
|
72
|
+
|
|
73
|
+
async def test_without_proxy():
|
|
74
|
+
"""不使用代理直接测试访问"""
|
|
75
|
+
print("=== 不使用代理直接访问 ===")
|
|
76
|
+
print(f"URL: {URL}")
|
|
77
|
+
|
|
78
|
+
try:
|
|
79
|
+
timeout = aiohttp.ClientTimeout(total=15)
|
|
80
|
+
async with aiohttp.ClientSession(timeout=timeout, headers=HEADERS, cookies=COOKIES) as session:
|
|
81
|
+
async with session.get(URL) as response:
|
|
82
|
+
print(f"状态码: {response.status}")
|
|
83
|
+
if response.status == 200:
|
|
84
|
+
print("直接访问成功")
|
|
85
|
+
return True
|
|
86
|
+
else:
|
|
87
|
+
print(f"直接访问失败,状态码: {response.status}")
|
|
88
|
+
return False
|
|
89
|
+
except Exception as e:
|
|
90
|
+
print(f"直接访问出错: {e}")
|
|
91
|
+
return False
|
|
92
|
+
|
|
93
|
+
|
|
94
|
+
async def test_with_proxy(proxy_url):
|
|
95
|
+
"""使用代理测试访问"""
|
|
96
|
+
print(f"\n=== 使用代理访问 ===")
|
|
97
|
+
print(f"代理地址: {proxy_url}")
|
|
98
|
+
print(f"URL: {URL}")
|
|
99
|
+
|
|
100
|
+
try:
|
|
101
|
+
timeout = aiohttp.ClientTimeout(total=15)
|
|
102
|
+
async with aiohttp.ClientSession(timeout=timeout, headers=HEADERS, cookies=COOKIES) as session:
|
|
103
|
+
# 处理带认证的代理
|
|
104
|
+
if "@" in proxy_url and "://" in proxy_url:
|
|
105
|
+
parsed = urlparse(proxy_url)
|
|
106
|
+
if parsed.username and parsed.password:
|
|
107
|
+
# 提取认证信息
|
|
108
|
+
auth = aiohttp.BasicAuth(parsed.username, parsed.password)
|
|
109
|
+
# 清理代理URL
|
|
110
|
+
clean_proxy = f"{parsed.scheme}://{parsed.hostname}"
|
|
111
|
+
if parsed.port:
|
|
112
|
+
clean_proxy += f":{parsed.port}"
|
|
113
|
+
|
|
114
|
+
print(f"使用带认证的代理: {clean_proxy}")
|
|
115
|
+
async with session.get(URL, proxy=clean_proxy, proxy_auth=auth) as response:
|
|
116
|
+
print(f"状态码: {response.status}")
|
|
117
|
+
if response.status == 200:
|
|
118
|
+
print("代理访问成功")
|
|
119
|
+
return True
|
|
120
|
+
else:
|
|
121
|
+
print(f"代理访问失败,状态码: {response.status}")
|
|
122
|
+
return False
|
|
123
|
+
else:
|
|
124
|
+
# 直接使用代理URL
|
|
125
|
+
print(f"使用代理: {proxy_url}")
|
|
126
|
+
async with session.get(URL, proxy=proxy_url) as response:
|
|
127
|
+
print(f"状态码: {response.status}")
|
|
128
|
+
if response.status == 200:
|
|
129
|
+
print("代理访问成功")
|
|
130
|
+
return True
|
|
131
|
+
else:
|
|
132
|
+
print(f"代理访问失败,状态码: {response.status}")
|
|
133
|
+
return False
|
|
134
|
+
except Exception as e:
|
|
135
|
+
print(f"代理访问出错: {e}")
|
|
136
|
+
return False
|
|
137
|
+
|
|
138
|
+
|
|
139
|
+
async def get_proxy_from_api():
|
|
140
|
+
"""从代理API获取代理"""
|
|
141
|
+
proxy_api = 'http://test.proxy.api:8080/proxy/getitem/'
|
|
142
|
+
print(f"\n=== 从代理API获取代理 ===")
|
|
143
|
+
print(f"API地址: {proxy_api}")
|
|
144
|
+
|
|
145
|
+
try:
|
|
146
|
+
timeout = aiohttp.ClientTimeout(total=10)
|
|
147
|
+
async with aiohttp.ClientSession(timeout=timeout) as session:
|
|
148
|
+
async with session.get(proxy_api) as response:
|
|
149
|
+
print(f"状态码: {response.status}")
|
|
150
|
+
|
|
151
|
+
if response.status == 200:
|
|
152
|
+
data = await response.json()
|
|
153
|
+
print(f"响应数据: {data}")
|
|
154
|
+
|
|
155
|
+
# 提取代理URL
|
|
156
|
+
if isinstance(data, dict) and data.get('status') == 0:
|
|
157
|
+
proxy_info = data.get('proxy', {})
|
|
158
|
+
if isinstance(proxy_info, dict):
|
|
159
|
+
proxy_url = proxy_info.get('https') or proxy_info.get('http')
|
|
160
|
+
if proxy_url:
|
|
161
|
+
print(f"提取到的代理URL: {proxy_url}")
|
|
162
|
+
return proxy_url
|
|
163
|
+
print("无法获取代理URL")
|
|
164
|
+
return None
|
|
165
|
+
except Exception as e:
|
|
166
|
+
print(f"API请求出错: {e}")
|
|
167
|
+
return None
|
|
168
|
+
|
|
169
|
+
|
|
170
|
+
async def main():
|
|
171
|
+
"""主测试函数"""
|
|
172
|
+
print("开始真实场景代理测试...")
|
|
173
|
+
print("=" * 50)
|
|
174
|
+
|
|
175
|
+
# 1. 首先测试不使用代理直接访问
|
|
176
|
+
direct_success = await test_without_proxy()
|
|
177
|
+
|
|
178
|
+
# 2. 从代理API获取代理
|
|
179
|
+
proxy_url = await get_proxy_from_api()
|
|
180
|
+
|
|
181
|
+
if not proxy_url:
|
|
182
|
+
print("\n无法获取代理,测试结束")
|
|
183
|
+
return
|
|
184
|
+
|
|
185
|
+
# 3. 使用代理访问
|
|
186
|
+
proxy_success = await test_with_proxy(proxy_url)
|
|
187
|
+
|
|
188
|
+
# 4. 测试结果总结
|
|
189
|
+
print(f"\n{'='*30}")
|
|
190
|
+
print("测试结果:")
|
|
191
|
+
print(f"直接访问: {'成功' if direct_success else '失败'}")
|
|
192
|
+
print(f"代理访问: {'成功' if proxy_success else '失败'}")
|
|
193
|
+
|
|
194
|
+
|
|
195
|
+
if __name__ == "__main__":
|
|
196
196
|
asyncio.run(main())
|
tests/test_redis_config.py
CHANGED
|
@@ -1,29 +1,29 @@
|
|
|
1
|
-
#!/usr/bin/env python3
|
|
2
|
-
# -*- coding: utf-8 -*-
|
|
3
|
-
"""
|
|
4
|
-
快速测试 Redis 连接配置修复
|
|
5
|
-
"""
|
|
6
|
-
import asyncio
|
|
7
|
-
from crawlo.queue.redis_priority_queue import RedisPriorityQueue
|
|
8
|
-
from crawlo.settings.default_settings import REDIS_URL
|
|
9
|
-
|
|
10
|
-
async def test_redis_config():
|
|
11
|
-
"""测试修复后的 Redis 配置"""
|
|
12
|
-
print(f"测试 Redis 配置: {REDIS_URL}")
|
|
13
|
-
|
|
14
|
-
try:
|
|
15
|
-
queue = RedisPriorityQueue(redis_url=REDIS_URL)
|
|
16
|
-
await queue.connect()
|
|
17
|
-
print("Redis 连接成功!")
|
|
18
|
-
await queue.close()
|
|
19
|
-
return True
|
|
20
|
-
except Exception as e:
|
|
21
|
-
print(f"Redis 连接失败: {e}")
|
|
22
|
-
return False
|
|
23
|
-
|
|
24
|
-
if __name__ == "__main__":
|
|
25
|
-
success = asyncio.run(test_redis_config())
|
|
26
|
-
if success:
|
|
27
|
-
print("配置修复成功!现在可以运行你的爬虫了。")
|
|
28
|
-
else:
|
|
1
|
+
#!/usr/bin/env python3
|
|
2
|
+
# -*- coding: utf-8 -*-
|
|
3
|
+
"""
|
|
4
|
+
快速测试 Redis 连接配置修复
|
|
5
|
+
"""
|
|
6
|
+
import asyncio
|
|
7
|
+
from crawlo.queue.redis_priority_queue import RedisPriorityQueue
|
|
8
|
+
from crawlo.settings.default_settings import REDIS_URL
|
|
9
|
+
|
|
10
|
+
async def test_redis_config():
|
|
11
|
+
"""测试修复后的 Redis 配置"""
|
|
12
|
+
print(f"测试 Redis 配置: {REDIS_URL}")
|
|
13
|
+
|
|
14
|
+
try:
|
|
15
|
+
queue = RedisPriorityQueue(redis_url=REDIS_URL)
|
|
16
|
+
await queue.connect()
|
|
17
|
+
print("Redis 连接成功!")
|
|
18
|
+
await queue.close()
|
|
19
|
+
return True
|
|
20
|
+
except Exception as e:
|
|
21
|
+
print(f"Redis 连接失败: {e}")
|
|
22
|
+
return False
|
|
23
|
+
|
|
24
|
+
if __name__ == "__main__":
|
|
25
|
+
success = asyncio.run(test_redis_config())
|
|
26
|
+
if success:
|
|
27
|
+
print("配置修复成功!现在可以运行你的爬虫了。")
|
|
28
|
+
else:
|
|
29
29
|
print("❌ 配置仍有问题,请检查 Redis 服务状态。")
|