百度站内搜索https不可用切换api搜索,加上谷歌api站内搜索
google推https几年了,百度开始宣传全面https,但是,百度站内搜索 自己的服务却不走https,接口报错。百度分享也是。
然后采用http://search.zhoulujun.cn/cse/search ,用了7-8个月的样子,还是继续,不声不响地 改变了配置了,突然就不通了——而且什么时候不通的都不知道
无赖,无奈,只有用google 自定义搜索引擎,用api 接口弄好
用google search API配置google站内搜索
谷歌搜索引擎定制化页面地址
https://cse.google.com/cse/setup/basic?cx=009558619093950188775:b3wc7giu_hw
复制 搜索引擎 ID ,保存
拖到最下面,找到
自定义搜索 JSON API
每天的查询数上限为 10000 次。
直接打开连接,可以阅读下内容,了解下
在此https://developers.google.com/custom-search/v1/overview
页面找到 API key,点击 GET A KEY 按钮,
复制key,保存
然后拼凑如下地址:
就是你的谷歌自定义站内搜索引擎
谷歌的就完成了,再来看下百度:
用百度站内搜索api配置百度站内搜索
登录百度站内页面,点击 进入API管理后台
新建搜索引擎,点击 代码示例
在代码里面获取如下代码地址:http://zhannei.baidu.com/api/customsearch/apiaccept?sid=6351075239166713563&v=2.0&callback=init
直接下载,上传自己服务,引用。
然后配置如下代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 | var cse ; //参数为您的API引擎ID,已自动填写,必需。 var form=document.querySelector( 'searchBaidu-bd' ); //关键词输入框 var textInput=document.getElementById( 'bdcsMain' ); //关键词输入框 var btnInput=document.getElementById( "search" ); //搜索按钮 var listBox=document.getElementById( "list" ); //搜索结果列表框 var exchange=document.getElementById( "exchange" ); //搜索结果列表框 var exchangeEngine=document.getElementById( "exchangeEngine" ); //搜索结果列表框 var searchEngine=document.getElementById( "searchEngine" ); //搜索结果列表框 let params=getUrlParams(window.location.search); let initKeyword=params[ 'q' ]; if (initKeyword){ initKeyword=decodeURIComponent(initKeyword); textInput.value=initKeyword; } var googleEnable= false ; function getUrlParams(str){ let obj={}; str.replace(/([^&=?]+)=([^&=?]*)/g, function (str,$1,$2) { obj[$1]=$2; return str; }); return obj; } function searchBaidu (text) { cse.getResult(text, function (data) { console.info( '百度搜索结果' ); console.log(data); createList(data,listBox) }); } function init () { cse= new BCse.Search( "6351075239166713563" ); initKeyword&&searchBaidu(initKeyword); } function createList(arr,select){ var str= '' ; if (arr&&arr.length){ let tempArr = arr.map( function (data) { return ' <li class="article-li ">' + ' <a class="" href="' +data.linkUrl+ '" target="_blank">' +data.title+ '</a>' + ' <time>' +data.dispTime+ '</time>' + ' </li>' ; }); str=tempArr.join( '' ); } else { str= '<li> 没有找到相关内容——the suitable context had not been found all the time. </li>' ; } select.innerHTML=str; searchEngine.innerHTML= '百度' ; exchangeEngine.innerHTML= '切换为谷歌搜索' ; } btnInput.addEventListener( 'click' , function (e) { e.preventDefault(); var text=textInput.value; if (googleEnable){ text&&searchByGoogle(text); } else { text&&searchBaidu(text); } }); exchange.addEventListener( 'click' , function (e) { e.preventDefault(); window.location= '?m=search&c=index&a=init&siteid=1&typeid=1&q=' +textInput.value; }); exchangeEngine.addEventListener( 'click' , function (e) { e.preventDefault(); var text=textInput.value; console.info( 'exchangeEngine.innerText' ); console.log( '__________' ); if (exchangeEngine.innerText=== '切换为百度搜索' ){ text&&searchBaidu(text); googleEnable= true ; return false ; } else { text&&searchByGoogle(text); googleEnable= false ; return false ; } }); function hndlr(response) { // console.log(JSON.stringify(response)); console.log(response); var str= '' ; if (response&&response.items&&response.items.length){ let tempArr = response.items.map( function (data) { return ' <li class="article-li ">' + ' <a class="" href="' +data.link+ '" target="_blank">' +data.htmlTitle+ '</a>' + ' </li>' ; }); str=tempArr.join( '' ); } else { str= '<li>没有找到相关内容</li>' ; } listBox.innerHTML=str; searchEngine.innerHTML= '谷歌' ; exchangeEngine.innerHTML= '切换为百度搜索' ; } function searchByGoogle(keyword){ $.ajax({ type: 'GET' , url: 'https://www.googleapis.com/customsearch/v1' , data: { q: keyword, key: 'AIzaSyC_pehzzjm8_6lbsegGNgct1-LaACSpvkM' , cx: '009558619093950188775:b3wc7giu_hw' , siteSearch: 'zhoulujun.cn' }, dataType: 'json' , success: function (data) { console.info( 'google搜索结果' ); console.log(data); googleEnable= true ; hndlr(data) }, error: function (data) { hndlr(); // let timer=setTimeout(function () { // searchBaidu(textInput.value); // clearTimeout(timer); // },800) } }); } searchByGoogle(initKeyword); /*function setBaidu () { var scriptEle=document.createElement('script'); scriptEle.src="{JS_PATH_CDN}andy/baidu.zn.js"; document.body.appendChild(scriptEle); }*/ |
具体代码和效果可以参看:
https://www.zhoulujun.cn/index.php?m=content&c=index&a=lists&catid=204&q=%E6%93%8D
没有做代码优化,只是抽点空把自己网站功能修复而已
按上面的操作的和应该可以配置
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了