자사 사이트에 Bing Custom Search 설치(사이트 내 검색)
Bing Custom Search 설치 방법
공식 매뉴얼을 알기 어렵기 때문에 비망록.
마이크로소프트 공식 매뉴얼: Bing Custom Search 빠른 시작
Google Custom Search는 광고가 끌려오므로 Bing에 리플레이스 하려고. Google Custom Search와 마찬가지로 <script> 태그를 포함하면 좋을 것이라고 매뉴얼을 보았지만 알기 어렵다.
【결론】 <script> 태그를 삽입하면 된다.
다음 절차.
Azure에서 Cognitive Services 구독 키 가져오기
우선은 서브스크립션 키를 바.
data:image/s3,"s3://crabby-images/87ae7/87ae7bc0cedb693531ee4c1093622b974c69adeb" alt=""
data:image/s3,"s3://crabby-images/c2d6c/c2d6c90387c5482ead2457e43b4264249bd53005" alt=""
data:image/s3,"s3://crabby-images/55502/55502230b0e6e52d4fd250caede2f204680f7014" alt=""
data:image/s3,"s3://crabby-images/40653/406531c17569fb05a97c266d32bdad2b17732d74" alt=""
data:image/s3,"s3://crabby-images/e0b9e/e0b9ec114898c079798ea11a1b32af89ae84ae17" alt=""
data:image/s3,"s3://crabby-images/1ccc9/1ccc9d26d7d4d79a6e804e219b7d94fb0781d6f1" alt=""
Bing Custom Search 인스턴스 만들기
이것은 공식 매뉴얼대로의 순서로 좋다.
data:image/s3,"s3://crabby-images/2ea92/2ea92b54e1fff12688473331ff3fb8117cc1aaea" alt=""
data:image/s3,"s3://crabby-images/fb505/fb505de46a0b9578951a4c786ca28fed6249a032" alt=""
data:image/s3,"s3://crabby-images/1a85b/1a85b14f0319b290a010900c66d480b042cbc8c5" alt=""
data:image/s3,"s3://crabby-images/aaf70/aaf7050714b2475b1cbe50f9188cc5137b1ddc55" alt=""
data:image/s3,"s3://crabby-images/93b62/93b62dbe2faafec843bbf74f6c3bc5601479cd13" alt=""
data:image/s3,"s3://crabby-images/a738d/a738d59d80e1d9bb5ceb693b5a2fa4f610c45a30" alt=""
data:image/s3,"s3://crabby-images/862bb/862bb76d6413cc8eaa48a42c1353cf5291ae504d" alt=""
data:image/s3,"s3://crabby-images/a1121/a11210484ae5e60d1d5b682f6f67da9aed09c8c7" alt=""
Call을 클릭하면 JSON이 돌아올 것입니다.
data:image/s3,"s3://crabby-images/5f3c9/5f3c907d75c34d3dd7b3f85130ab08ba923591ea" alt=""
data:image/s3,"s3://crabby-images/13406/1340658db220257e7854fc12482abcbe10fa1125" alt=""
Bing Custom Search エンドポイントを呼び出す
다음 단계, 그리고 매뉴얼에는 Node.js を使用して Bing Custom Search エンドポイントを呼び出す 에 가는 버튼이 있지만, 이것도 필요한 순서일까 헤매지만, 필요하지 않다. 표시 화면을 커스터마이즈하고 싶다면 필요하다.
スクリプトコードを埋め込む
우리 Angular8이므로 스크립트 코드는 포함할 수 없습니다.
이하의 방법으로 했다.
.ts
ngOnInit() {
const script = document.createElement('script');
script.async = true;
script.type="text/javascript";
script.src = 'https://ui.customsearch.ai/api/ux/rendering-js?customConfig=fcbxxxx3-xxxx-xxxxx-xxxxx-eexxxxa516c2&market=ja-JP&version=latest&q=';
script.id = 'bcs_js_snippet';
const div = document.getElementById('script');
div.insertAdjacentElement('afterend', script);
}
HTML
<div id="script"></div>
우선 이상.
検索結果を表示したあと、表示をリセットする
Google Custom Search와 같이 표시 결과를 다른 페이지에 호출하는 옵션이 없기 때문에 SPA라면 다른 화면으로 날아도 표시되지 않습니다. 간단한 해결 방법은 페이지 재로드.
버튼을 붙여 클릭하면 다시 로드하도록 했다.
data:image/s3,"s3://crabby-images/7a174/7a1741ad33e7d85831f784877942ce0e0d618ed6" alt=""
HTML
<table style="border: white; border:0; width: 100%;">
<tr>
<td style="width: 95%">
<div id="script"></div>
</td>
<td style="width: 5%; vertical-align: top;">
<button style="margin-left: 0.5em;" class="simple_square_btn2" (click)="reset()">
表示<br>リセット
</button>
</td>
</tr>
</table>
CSS
.simple_square_btn2 {
display: block;
position: relative;
width: 50px;
height: 46px;
padding: 0.3em;
text-align: center;
font-size: x-small;
text-decoration: none;
color: #1B1B1B;
background: #fff;
border:1px solid #1B1B1B;
}
TS
// サーチクリア関数(リロードするだけ)
reset() {
location.reload();
}
Appendix:Angularでエンドポイントを呼び出すコード
커스터마이즈하고 싶은 경우의 코드는 Angular의 경우, 어떠한 느낌일까? 테스트하지 않기 때문에 움직이지 않는다고 생각한다. 어디까지나 이미지.
TS
import { Component, OnInit } from '@angular/core';
import { Observable } from "rxjs";
import { HttpClient,HttpHeaders,HttpParams } from '@angular/common/http';
class bing {
name: string;
url: string;
displayUrl; string;
snippet: string;
dateLastCrawled: string;
}
@Component({
selector: 'app-bing',
templateUrl: './bing.component.html',
styleUrls: ['./bing.component.css']
})
export class BingComponent implements OnInit {
bingObservable: Observable<bing[]>;
subscriptionKey = 'a053xxxxxxxxxxxxxxxxxxxxf4ac'; //'YOUR-SUBSCRIPTION-KEY'
customConfigId = 'fcbxxxx3-xxxx-xxxx-9676-ee7xxxxx516c2'; //'YOUR-CUSTOM-CONFIG-ID';
searchTerm = '';
url = 'https://bij.cognitiveservices.azure.com/bingcustomsearch/v7.0/search?' +
'q=' + this.searchTerm + '&' + 'customconfig=' + this.customConfigId + '&' + 'mkt=ja-JP';
options = {
headers: new HttpHeaders().append("Ocp-Apim-Subscription-Key", this.subscriptionKey),
params: new HttpParams().append("url", this.url)
}
loadBing() {
this.bingObservable = this.http.get<bing[]>(this.url, this.options);
console.log('◆' + this.bingObservable)
}
constructor() {
}
ngOnInit() {
}
HTML
<ul *ngIf="bingObservable| async as results else empty">
<li *ngFor="let result of results">
</li>
</ul>
참조:
Angular 9/8 Http - How to Use HttpClient Module with Examples
Angularのテンプレート内で script タグを読み込む方法
how to use bing search in my angular app.?
Reference
이 문제에 관하여(자사 사이트에 Bing Custom Search 설치(사이트 내 검색)), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/atomyah/items/ceeeba84bbd7dc642997텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)