안드로이드 열화상 카메라는 열원을 탐지할 수 있습니다...">
,需要通过父级DOM结构来判断
*/
var trackActionPhone = function (node) {
var nodeInnerText = node.innerText || '';
if (!limitRegLength(nodeInnerText)) return;
var nodeText = trimText(nodeInnerText);
if (nodeText.length < 5 || nodeText.length > 20) return false;
var type =
arguments.length > 1 && arguments[1] !== undefined
? arguments[1]
: 'click';
var str = trimText(node.href || node.innerHTML || '');
if (phoneReg.test(str) && numUseReg.test(str)) {
_paq.push(['trackEvent', type, 'phone', nodeText]);
return true;
}
/** 排查父级嵌套非标签场景,并且对dom的正则校验做一个性能兜底,通过控制innerText的长度,来确保正则的性能 */
var fatherText = trimText(node.parentNode.innerText || '');
if (fatherText.length < 5 || fatherText.length > 20) return false;
var fatherDom = trimText(node.parentNode.innerHTML || '');
if (phoneReg.test(fatherDom) && numUseReg.test(fatherDom)) {
_paq.push(['trackEvent', type, 'phone', nodeText]);
return true;
}
return false;
};
window.addEventListener('click', function (e) {
var node = e.target;
/** 社媒点击 */
var appName = '';
var getAppAriaLabel =
node.ariaLabel || node.parentNode.ariaLabel || '';
if (mediaList.includes(getAppAriaLabel.toLowerCase())) {
appName = getAppAriaLabel;
}
if (
!appName &&
node.nodeName &&
node.nodeName.toLowerCase() === 'a'
) {
appName = getMediaName(node.href) || getMediaName(node.alt);
}
if (
!appName &&
node.nodeName &&
node.nodeName.toLowerCase() === 'img'
) {
appName = getMediaName(node.alt) || getMediaName(node.src);
}
if (
!appName &&
node.nodeName &&
node.nodeName.toLowerCase() === 'i'
) {
appName = getMediaName(node.className);
}
if (appName) {
_paq.push(['trackEvent', 'click', 'contactApp', appName]);
return;
}
/** 联系方式点击 */
if (trackActionPhone(node, 'click')) return;
if (node.nodeName && node.nodeName.toLowerCase() === 'a') {
var val = node.href;
if (!limitRegLength(val)) return;
if (emailReg.test(val)) {
_paq.push(['trackEvent', 'click', 'email', val]);
return;
}
}
if (node.nodeName && node.nodeName.toLowerCase() === 'i') {
var val = node.className;
var content = node.parentNode.href || '';
if (val.includes('email')) {
_paq.push(['trackEvent', 'click', 'email', content]);
return;
}
}
var nodeChildList = node.childNodes;
for (var i = 0; i < nodeChildList.length; i++) {
if (nodeChildList[i].nodeType !== 3) continue;
var val = nodeChildList[i].textContent.replace(/\s?:?/g, '');
if (!limitRegLength(val)) continue;
if (emailReg.test(val)) {
_paq.push(['trackEvent', 'click', 'email', val]);
return;
}
}
trackNumberData(node);
});
window.addEventListener('copy', function (e) {
if (trackActionPhone(e.target, 'copy')) return;
var text = e.target.textContent;
if (!text) return;
var val = text.replace(/\s:?/g, '');
if (!limitRegLength(val)) return;
if (emailReg.test(val)) {
_paq.push(['trackEvent', 'copy', 'email', val]);
return;
}
trackNumberData(e.target);
});
}
trackContactInit();
/**
* 基于custom_inquiry_form.js 以及 form.js 对于询盘表单提交的实现,来反推询盘表单的input标签触发,用来收集意向客户
* 1. 缓存的KEY:TRACK_INPUT_ID_MTM_00;
* 2. 缓存策略 - lockTrackInput:单个页面内,10分钟内,不重复上报
*/
function trackActionInput() {
const CACHE_KEY = 'TRACK_INPUT_ID_MTM_00';
const pathName = window.location.hostname + window.location.pathname;
var lockTrackInput = function () {
try {
const lastCacheData = localStorage.getItem(CACHE_KEY);
if (!lastCacheData) return false;
const cacheData = JSON.parse(lastCacheData);
const cacheTime = cacheData[pathName];
if (!cacheTime) return false;
return Date.now() - cacheTime < 1000 * 60 * 10; // 10分钟内,不重复上报
} catch (error) {
console.error('lockTrackInput Error', error);
return false;
}
};
var setInputTrackId = function () {
try {
const curCacheData = localStorage.getItem(CACHE_KEY);
if (curCacheData) {
const cacheData = JSON.parse(curCacheData);
cacheData[pathName] = Date.now();
localStorage.setItem(CACHE_KEY, JSON.stringify(cacheData));
return;
}
const cacheData = {
[pathName]: Date.now(),
};
localStorage.setItem(CACHE_KEY, JSON.stringify(cacheData));
} catch (error) {
console.error('setInputTrackId Error', error);
}
};
var getInputDom = function (initDom) {
var ele = initDom;
while (ele) {
/**
* isWebSiteForm 是站点的表单
* isChatWindowForm 是聊天窗口的表单
*/
/** 旧模板表单 */
var isWebSiteForm = !!(
/crm-form/i.test(ele.className) && ele.querySelector('form')
);
/** 1:新模板自定义表单、2:Get a Quote 弹框表单 */
var isWebSiteFormNew = !!(
/inquiry/i.test(ele.className) && ele.querySelector('form')
);
if (isWebSiteForm || isWebSiteFormNew) {
_paq.push(['trackEvent', 'formInquiry', 'formInput', 'page']);
setInputTrackId();
return;
}
/** Mkt会话触达-聊天弹框的表单输入: MKT由于是iframe嵌入,所以MKT的上报,会单独写到MKT-form代码上 */
var isInquiryChatForm = !!(
/comp-form/i.test(ele.className) && ele.querySelector('form')
);
if (isInquiryChatForm) {
_paq.push(['trackEvent', 'formInquiry', 'formInput', 'chat']);
setInputTrackId();
return;
}
/** 向上查找父节点 */
ele = ele.parentNode;
}
};
function initInputListener() {
var inputUseDebounce = function (fn, delay) {
var timer = null;
var that = this;
return function () {
var args = Array.prototype.slice.call(arguments);
if (timer) clearTimeout(timer);
timer = setTimeout(function () {
fn.apply(that, args);
}, delay);
};
};
var optimizeGetInputDom = inputUseDebounce(getInputDom, 300);
window.addEventListener('input', function (e) {
/** 如果已经上报过,则不再上报 */
if (lockTrackInput()) return;
optimizeGetInputDom(e.target);
});
}
try {
initInputListener();
} catch (error) {
console.log('initInputListener Error', error);
}
}
trackActionInput();
}
/** 第三方消息上报:目前主要是针对全点托管会话;在msgCollect/index.js中调试,访问test.html */
function thirdMsgCollect() {
/** 先检测是否是stayReal托管:如果stayReal脚本都没有,那么说明当前站点未开启stayReal会话托管 */
const scriptList = Array.prototype.slice.call(
document.querySelectorAll('script'),
);
const checkStayReal = () =>
!!scriptList.find((s) => s.src.includes('stayreal.xiaoman.cn'));
if (!checkStayReal()) return;
/** 缓存当前消息队列的最后一条消息id */
const CACHE_KEY = 'CACHE_KEY_MONITOR';
const setCache = (msgIndex) => {
/** 对缓存KEY进行base64转码处理 */
const cacheMsgIndex = btoa(msgIndex);
localStorage.setItem(CACHE_KEY, cacheMsgIndex);
};
const getCache = () => {
const cacheMsgIndex = localStorage.getItem(CACHE_KEY);
if (cacheMsgIndex) return Number(atob(cacheMsgIndex));
return -1;
};
/** 拉取最新msg列表 */
const pullMsgList = () => {
const msgEleList = Array.prototype.slice.call(
document.querySelectorAll('#chat-list li'),
);
const msgIds = [];
const msgMap = msgEleList.reduce((acc, item) => {
const sendTime = item
.querySelector('.message-data-time')
.textContent.trim();
const sendContent = item.querySelector('.message').textContent.trim();
/** msg带有class:other-message的是访客消息,my-message的是客服消息 */
const isOtherMessage = item
.querySelector('.message')
.classList.contains('other-message');
const msgId = item.querySelector('.message').getAttribute('id');
const msgItemData = {
msgId,
user: isOtherMessage ? 'visitor' : 'official',
time: sendTime,
content: sendContent,
};
msgIds.push(msgId);
acc[msgId] = msgItemData;
return acc;
}, {});
return {
ids: msgIds,
dataMap: msgMap,
};
};
/** 加密并上传消息数据 */
let ENCRYPT_KEY = 'de29f1aab63ab033';
let ENCRYPT_IV = 'b8d2badf875e76ac';
const baseUrl = 'https://cms.xiaoman.cn';
// var getEncryptConfig = function () {
// const url = baseUrl + '/shop-api/innerApi/getKeyIv'
// $.get(
// url,
// function (result) {
// console.log('result', result)
// if (Number(result.code) === 0 && result.data.key && result.data.iv) {
// ENCRYPT_KEY = result.data.key
// ENCRYPT_IV = result.data.iv
// uploadMsgData()
// } else {
// /** 如果获取失败,则重试 */
// setTimeout(() => {
// getEncryptConfig()
// }, 1000)
// }
// },
// 'json'
// )
// }
// getEncryptConfig()
const encryptMsg = function (msgData) {
const enc = new TextEncoder();
// 转字节
const keyBytes = enc.encode(ENCRYPT_KEY);
const ivBytes = enc.encode(ENCRYPT_IV);
const plainBytes = enc.encode(msgData);
// 导入密钥并加密
return crypto.subtle
.importKey('raw', keyBytes, { name: 'AES-CBC' }, false, ['encrypt'])
.then(function (cryptoKey) {
return crypto.subtle.encrypt(
{ name: 'AES-CBC', iv: ivBytes },
cryptoKey,
plainBytes,
);
})
.then(function (encryptedBuffer) {
// 转 base64 返回
return btoa(
String.fromCharCode(...new Uint8Array(encryptedBuffer)),
);
})
.catch((err) => {
return Promise.reject(err);
});
};
let uploadFlag = false;
const uploadMsgData = function () {
if (uploadFlag) return;
uploadFlag = true;
const { ids, dataMap } = pullMsgList();
let cacheMsgIndex = getCache();
const msgLen = ids.length;
if (!msgLen) {
// 消息DOM未挂载 || 消息DOM已挂载,但是消息列表为空
uploadFlag = false;
return;
}
if (msgLen - 1 < cacheMsgIndex) {
/** 针对站点挂后台一段时间,消息列表会自动塞入重复消息,导致消息有重复,刷新后又重置回正常消息列表,所以这里需要更新锚点下标 */
cacheMsgIndex = msgLen - 1;
setCache(cacheMsgIndex);
uploadFlag = false;
return;
}
if (msgLen - 1 === cacheMsgIndex) {
// 缓存的最后一次发送的消息ID是最后一条(说明当前消息均已经上报),则不跳过本地上报
uploadFlag = false;
return;
}
const currentMsgIds = ids.slice(cacheMsgIndex + 1, msgLen);
const currentMsgData = currentMsgIds.map((id) => dataMap[id]);
const mtmId = window.matomo_site_id_cookie_key || ''; // 获取mtm会话id
const msgBody = {
mtmId,
curl: window.location.href,
msgList: currentMsgData,
};
const msgBodyStr = JSON.stringify(msgBody);
encryptMsg(msgBodyStr)
.then(function (encryptedMsg) {
console.log('encryptedMsg:', encryptedMsg, msgBodyStr);
const url = baseUrl + '/shop-api/External/ListenSiteActiveStatus';
$.ajax({
type: 'POST',
url,
data: JSON.stringify({ d_v: encryptedMsg }),
contentType: 'application/json',
success: function (result) {
if (Number(result.code) === 0) {
// 更新消息队列
setCache(msgLen - 1);
}
uploadFlag = false;
},
error: function (err) {
console.error(err, '请求异常');
uploadFlag = false;
},
});
})
.catch((err) => {
console.error(err, '数据加密失败');
uploadFlag = false;
});
};
/** 监控chat-list的DOM变更 */
const initChatListObserver = () => {
// 需要监听的 DOM 节点
const target = document.getElementById('chat-list');
if (!target) return;
// 回调函数
const callback = function (mutationsList, observer) {
for (const mutation of mutationsList) {
console.log('mutation', mutation);
if (mutation.type === 'childList') {
uploadMsgData();
}
}
};
// 配置
const config = {
childList: true, // 监听子节点的增删
subtree: true, // 是否也监听后代节点
};
// 创建 observer
const observer = new MutationObserver(callback);
// 开始监听
observer.observe(target, config);
};
let testCount = 30;
let itv = null;
const checkChatDom = () => !!document.querySelector('#vc-model');
const initTalkCheck = () => {
itv = setTimeout(() => {
console.log('checkChatDom', checkChatDom(), testCount);
if (!checkChatDom() && testCount > 0) {
testCount--;
initTalkCheck();
return;
}
clearTimeout(itv);
uploadMsgData();
initChatListObserver();
}, 1500);
};
initTalkCheck();
}
try {
gtmTrack();
thirdMsgCollect();
console.log('inserted gtm code');
} catch (error) {
console.error('gtmTrack Error', error);
}
});
})();
홈페이지 /
더 말할 필요가 있을까요? 어떻게 안드로이드 열화상 카메라 는 우리가 눈으로 보기 어려운 것을 볼 수 있도록 특별히 설계되었습니다. 그들은 열을 감지하고 이를 우리의 눈으로 볼 수 있는 색상 스펙트럼으로 변환합니다. 열을 볼 수 있는 경우가 많아 매우 유용하며, 이것이 우리에게 큰 도움을 줄 수 있습니다. 이러한 작업에서 사용되는 카메라는 소방과 경찰 업무뿐만 아니라 건물이 위험해지기 전에 점검하는 데도 사용됩니다. LSJ Technology에서 고품질이고 합리적인 가격의 열화상 카메라를 찾아보는 것으로 시작해 보세요. 열화상 카메라는 많은 이점이 있습니다. 주요 장점 중 하나는 열을 감지할 수 있다는 것입니다. 이를 통해 우리가 보지 못하는 것을 관찰할 수 있습니다. 예를 들어, 소방관은 이러한 카메라를 사용하여 짙은 연기를 뚫고(매우 위험할 수 있음) 화재 건물 안에서 갇힌 사람들을 찾을 수 있습니다. 이는 생명을 구하는데 도움이 될 수 있습니다! 열화상 카메라는 경찰이 숨겨진 무기나 어두운 곳에 숨어있는 사람들을 발견하기 위해 사용될 수도 있습니다. 이를 통해 그들은 더 안전하게 업무를 수행할 수 있습니다. 열화상 카메라는 관찰 대상과 물리적으로 접촉하지 않는다는 추가적인 이점도 있습니다. 이것은 건물, 전기 가전제품 및 기타 사물들을 아무것도 부수지 않고 검사할 수 있게 해줍니다. 예를 들어, 전기 장비를 다룰 때에도 카메라는 어떤 것을 분해하지 않으면서도 핫스팟을 찾는 데 사용될 수 있습니다. 이는 점검과 수리에 놀랍게 작용합니다. 어떻게 열화상 카메라 안드로이드 작동 방식은? 그들은 다양한 물체가 방출하는 열을 감지합니다. 이 카메라는 기본적으로 물체가 방출하는 열 에너지를 초점에 맞추는 데 특히 유용한 특수 렌즈를 가지고 있습니다. 그런 후, 이러한 원자의 온도가 카메라의 검출기에 방출됩니다. 검출기는 열 에너지를 전기 신호로 변환합니다. 그리고 카메라 소프트웨어는 그 신호를 사진으로 변환하여 열원을 시각적으로 보여줍니다. 이것이 바로 우리가 특정 과정이 없었으면 불가능했을 일들을 볼 수 있는 이유입니다! 열화상 카메라 LSJ Tech는 다양한 용도를 위한 여러 종류의 열화상 카메라를 제공합니다. 우리의 Fire Cam 소방 헬멧 카메라는 튼튼하게 만들어져 있으며 혹독한 환경에서도 견딜 수 있습니다. 또한, 더 넓은 감시 지역을 커버해야 할 때 중요한 넓은 시야와 선명한 화면을 제공합니다. 우리는 건물 검사용으로 작은 크기이면서도 효과적이고 사용하기 쉬운 카메라를 사용합니다. 이들의 기능에는 시야 안내를 돕는 레이저 포인터와 이미지를 더욱 개선하는 영상 강화 기능이 포함됩니다. 요즘에는 열화상 카메라의 도움을 받아 이 기술을 더욱 발전시키고 있습니다. 오늘날의 카메라들은 과거보다 훨씬 우수한 기능들을 갖추고 있습니다. 소프트웨어는 영상 강화, 디지털 줌과 같은 다양한 기능을 제공하여 고급 출력을 생성하고 온도를 정확히 측정할 수 있도록 합니다. LSJ Technology에서는 열화상 카메라가 다음 세 가지 목표를 달성하는 데 도움이 될 수 있다고 믿습니다: 안전 증진, 생명 구조 및 재산 보호입니다. 우리는 이 놀라운 기술을 모두가 사용할 수 있도록 하고 싶어 고급 카메라에 대한 생각을 여전히 간직하고 있습니다. 다양한 직업의 사람들에게 더 간단하고 안전하게 일할 수 있도록 열화상 카메라를 사용할 수 있게 하기 위해서입니다. 열화상 카메라 분야에서 LSJ는 고품질의 탐색 및 구조 장비, 소방 장비를 개발·제조·공급해 왔습니다. LSJ는 ISO9001, CE, ROHS 인증을 획득하였으며, 30건 이상의 특허를 보유하고 있습니다. 당사는 선도 기업으로서 연구 및 설계 부문에 막대한 투자를 지속하고 있습니다. 2024년 LSJ는 두바이 INTERSEC, 러시아 Securika 2024, 말레이시아 제18차 Defence Services Asia(DSA) 및 제3차 National Security Asia(NATSEC), 미국 NFPA 등 4개 주요 전시회에 참가하였습니다. 또한 2025년 1월 14일~16일 두바이 INTERSEC 전시회에 공식 부스를 운영할 예정입니다. 이 행사에서는 벽을 투과해 생존자를 탐지하는 레이더 생명 탐지기(Radar Life Detector), 3D 레이더, 가스 탐지기, 음향 및 영상 청취 장치, 안정성 모니터링 장비, 화재 진압용 열화상 카메라 등을 선보일 예정입니다. 귀하의 방문을 진심으로 환영합니다. LSJ는 11년 이상의 제조 경험을 바탕으로 고객의 실제 사용 시나리오에 따라 제품을 재설계하고 신규 제품을 제작하며, 기능을 지속적으로 업그레이드하고 제품 비용을 점진적으로 절감해 왔습니다. 특히 도시 구조 및 탐색 분야에서 풍부한 실무 경험을 보유하고 있으며, 2023년 터키 지진 당시 중국 ‘블루스카이 구조대(Blue Sky Rescue Team)’의 구조 활동에서 LSJ 레이더 생명 탐지기가 핵심적인 역할을 수행하였습니다. 귀사의 요구사항에 정확히 부합하는 첨단적이고 신뢰성 높은 솔루션을 위해 LSJ를 선택해 주십시오. LSJ는 국제적으로 가장 엄격한 기준을 충족하도록 설계된 고품질 도시 탐색 및 구조 장비용 열화상 카메라 전문 기업입니다.
사전 판매 서비스:
저희는 고객 지원을 처음부터 시작합니다. 고객의 니즈를 파악하고 맞춤형 솔루션을 제공하기 위해 종합적인 컨설팅을 실시합니다. 또한, 고객이 정보에 기반한 결정을 내릴 수 있도록 제품의 상세한 기술 사양서와 시연을 제공해 드립니다.
판매 서비스:
판매 과정에서 고객께서 원활하고 효과적인 경험을 하실 수 있도록 최선을 다합니다. 효율적인 주문 시스템과 엄격한 품질 관리를 통해 제품이 정해진 기간 내에 완벽한 상태로 도착함을 보장합니다. 도어투도어(Door-to-Door) 배송도 지원합니다.
사후 서비스:
제품 수령 후에도 고객과의 관계는 끝나지 않습니다. 설치 지원, 사용자 교육, 정비 서비스 등 포괄적인 사후 지원을 제공합니다. 언제든지 연락 가능한 전담 고객 서비스 팀이 있으며, 고객의 모든 문의나 우려 사항을 신속히 해결하여 만족도를 높이기 위해 최선을 다합니다. LSJ에서 구매하시는 모든 장비에 대해 3년 무상 보증을 제공합니다. 또한, 지속적인 사후 지원도 가능합니다.
LSJ를 선택한다는 것은 신뢰, 품질, 그리고 차별화된 지원을 선택하는 것입니다. 도시 탐색 및 구조 분야와 소방 분야에서 귀사의 파트너가 되기를 기대합니다. 저희는 소방 및 구조 대대, 공공 안전 서비스, 도시 구조 대원, 기타 군사 부대에 서비스를 제공합니다. LSJ는 다양한 산업 분야에서 화재 진압, 수색 및 구조 작전 수행, 위험 지역 작업을 위한 열화상 카메라를 제공합니다.
소방용 열화상 카메라: 저희는 해상도가 256×192, 384×288, 640×512인 세 가지 선택지로 구성된 두 종류의 열화상 카메라를 개발했습니다. 이 카메라는 최대 2000℃까지 온도를 측정할 수 있습니다.
수색 및 구조 장비: 당사 제품군에는 레이더 기반 생명 탐지기, 벽 투과형 3D 레이더, 구조물 안정성 모니터링 시스템, 움직임 감지 시스템, 가스 탐지기 등이 포함됩니다.
산업용 열화상 카메라: 소방 전용 열화상 카메라 외에도 LSJ는 물 누출 탐지 및 건물 점검, 전자기기 수리, 바닥 난방 열손실 측정, HVAC 시스템 점검을 위한 휴대용 열화상 카메라를 제공합니다.
열화상 스코프 및 야간 투시 스코프: 당사의 야간 투시 스코프는 야간 시인성을 위해 최적화되었으며 사냥꾼들 사이에서 인기가 높습니다. 이 스코프는 소총에 쉽게 장착할 수 있습니다.
LSJ는 다양한 산업 분야의 요구를 충족시키는 고품질 열안전 및 열영상 장비를 제공함으로써 현장 작업자의 효율성과 안전성을 향상시킵니다. 최신식이며 효율적인 솔루션을 원하신다면 LSJ를 선택하세요.
도시 구조 분야에서 LSJ를 귀하의 첫 번째 파트너로 신뢰해 주십시오. LSJ는 고객에게 고품질 제품과 뛰어난 서비스를 제공하는 것이 얼마나 중요한지 잘 인식하고 있습니다. 당사는 제품의 오랜 내구성과 우수한 성능에 대한 자신감을 바탕으로, 단일 또는 열화상 카메라에 대해 보증 서비스를 제공합니다. 당사가 연구개발(R&D) 분야에 막대한 투자를 지속함으로써, 고객께서는 최고 수준의 기준을 충족하는 제품을 공급받게 됩니다. 제조업체로서 당사는 원자재 조달부터 최종 생산까지 엄격한 품질 관리를 철저히 준수합니다. 당사는 모든 사용자의 요구를 충족시킬 수 있는 광범위한 제품군을 제공합니다. 또한 주문된 제품을 신속히 납품할 수 있도록 부품 및 원자재에 대한 종합적인 재고를 유지하고 있습니다. 만일 약정된 납기일 내에 납품을 완료하지 못할 경우, 당사는 고객에게 주문 금액의 2~5%를 환불해 드릴 것을 약속합니다. 고객께서 당사 제품을 효과적으로 활용하실 수 있도록, 포괄적인 사용 설명 영상 자료를 제공합니다. 또한 고객의 구체적인 요구 사항에 맞춘 현장 기술 교육을 별도로 마련해 드릴 수 있으며, 이를 통해 고객께서 당사 제품을 자신 있게 그리고 쉽게 사용하실 수 있도록 지원합니다. 고품질·신뢰성 높은 제품과 뛰어난 고객 서비스를 원하신다면 LSJ를 선택해 주십시오. 저작권 © 베이징 LSJ 테크놀로지 디벨롭먼트 코., 리미티드. 모든 권리 보유
-
개인정보 보호정책
열화상 카메라
열 영상 카메라 작동 원리

열화상 카메라

열 영상 카메라 기술의 배경

열 영상 카메라를 이용한 열 탐지의 힘을 해방시키다
Why choose LSJ Technology 열화상 카메라?
고성능 수색 구조 장비 제조업체 혁신
왜 LSJ가 당신의 프라이머 제조업체 및 공급업체가 될 수 있는지?
완벽한 도시 구조물 탐색 및 구조 장비 공급망
품질과 적시 배송 보장: LSJ의 고객 만족 약속
원하는 내용을 찾지 못하셨나요?
지금 견적 요청하기
더 많은 이용 가능한 제품은 전문가와 상담해 주세요.문의하기