signature=c61154df25291f1682b183cb1b7b370f,node.js - NodeJS UNABLE_TO_VERIFY_LEAF_SIGNATURE - Stack ...

To answer the first question about using a bundled version of OpenSSL:

node generates static objects during compile based on the needs of the crypto api.

For example the crypto API requires the following OpenSSL function calls:

$ nm /usr/local/bin/node | grep "openssl\|x509\|pkey\|tls"

0000000000953d40 T CMS_RecipientInfo_set0_pkey

000000000095c580 T DSO_METHOD_openssl

00000000008dc790 T ENGINE_get_pkey_asn1_meth

00000000008dc7e0 T ENGINE_get_pkey_asn1_meth_engine

00000000008dc590 T ENGINE_get_pkey_asn1_meth_str

00000000008dc4e0 T ENGINE_get_pkey_asn1_meths

00000000008dcea0 T ENGINE_get_pkey_meth

00000000008dcef0 T ENGINE_get_pkey_meth_engine

00000000008dcdf0 T ENGINE_get_pkey_meths

00000000008dc500 T ENGINE_pkey_asn1_find_str

00000000008dc8d0 T ENGINE_register_all_pkey_asn1_meths

00000000008dcfe0 T ENGINE_register_all_pkey_meths

00000000008dc860 T ENGINE_register_pkey_asn1_meths

00000000008dcf70 T ENGINE_register_pkey_meths

00000000008dc800 T ENGINE_set_default_pkey_asn1_meths

00000000008dcf10 T ENGINE_set_default_pkey_meths

00000000008dc4f0 T ENGINE_set_pkey_asn1_meths

00000000008dce00 T ENGINE_set_pkey_meths

00000000008dc910 T ENGINE_unregister_pkey_asn1_meths

00000000008dd020 T ENGINE_unregister_pkey_meths

00000000008e7a40 T EVP_MD_pkey_type

00000000008eaae0 T EVP_PKEY_CTX_get0_pkey

00000000008fbad0 T PKCS12_certbag2x509

00000000008fba70 T PKCS12_certbag2x509crl

00000000008fbb50 T PKCS12_x5092certbag

00000000008fbb30 T PKCS12_x509crl2certbag

00000000008ba910 T PKCS8_pkey_get0

00000000008ba9d0 T PKCS8_pkey_set0

000000000093d860 T SSL_CTX_set_tlsext_use_srtp

000000000093d840 T SSL_set_tlsext_use_srtp

00000000007bd110 T _ZN2v88internal9Assembler9cvtlsi2sdENS0_11XMMRegisterENS0_8RegisterE

00000000007bd1b0 T _ZN2v88internal9Assembler9cvtlsi2sdENS0_11XMMRegisterERKNS0_7OperandE

00000000007bd070 T _ZN2v88internal9Assembler9cvtlsi2ssENS0_11XMMRegisterENS0_8RegisterE

000000000087d220 t _ZN4node6cryptoL14VerifyCallbackEiP17x509_store_ctx_st

0000000000a821a0 r _ZN4nodeL10tls_nativeE

0000000000eac550 B app_pkey_methods

0000000000b16320 R cmac_pkey_meth

0000000000b183a0 R dh_pkey_meth

000000000093b210 T do_dtls1_write

0000000000962a60 t do_pk8pkey

0000000000962cb0 t do_pk8pkey_fp

00000000008cb340 t dsa_pkey_ctrl

0000000000b18660 R dsa_pkey_meth

0000000000938f40 t dtls1_add_cert_to_buf

0000000000938730 T dtls1_buffer_message

000000000093b9f0 t dtls1_buffer_record

000000000093a7d0 T dtls1_check_timeout_num

000000000093ad90 T dtls1_clear

000000000093ac20 t dtls1_clear_queues

00000000009385f0 T dtls1_clear_record_buffer

000000000093b8b0 t dtls1_copy_record

000000000093abc0 T dtls1_ctrl

000000000093a760 T dtls1_default_timeout

000000000093b610 T dtls1_dispatch_alert

0000000000939b00 T dtls1_do_write

000000000093aae0 T dtls1_double_timeout

000000000096d500 T dtls1_enc

000000000093aee0 T dtls1_free

00000000009384f0 T dtls1_get_ccs_header

000000000093aba0 T dtls1_get_cipher

00000000009398b0 T dtls1_get_message

0000000000939260 t dtls1_get_message_fragment

0000000000938510 T dtls1_get_message_header

0000000000938440 T dtls1_get_queue_priority

000000000093c050 T dtls1_get_record

000000000093a910 T dtls1_get_timeout

000000000093ab20 T dtls1_handle_timeout

00000000009385b0 t dtls1_hm_fragment_free

0000000000938640 t dtls1_hm_fragment_new

000000000093aa10 T dtls1_is_timer_expired

000000000093a770 T dtls1_listen

00000000009384d0 T dtls1_min_mtu

000000000093af70 T dtls1_new

0000000000939010 T dtls1_output_cert_chain

0000000000938e10 t dtls1_preprocess_fragment

000000000093bbf0 t dtls1_process_record

000000000093c480 T dtls1_read_bytes

0000000000938d70 T dtls1_read_failed

0000000000938950 t dtls1_reassemble_fragment

000000000093b160 T dtls1_reset_seq_numbers

000000000093a390 T dtls1_retransmit_buffered_messages

000000000093a0f0 T dtls1_retransmit_message

000000000093b990 t dtls1_retrieve_buffered_record

000000000093a450 T dtls1_send_change_cipher_spec

000000000093a560 T dtls1_send_finished

0000000000938450 T dtls1_set_message_header

00000000009384e0 T dtls1_shutdown

000000000093aa50 T dtls1_start_timer

000000000093a880 T dtls1_stop_timer

0000000000b0bca0 R dtls1_version_str

000000000093b7d0 T dtls1_write_app_data_bytes

000000000093b760 T dtls1_write_bytes

00000000008cd650 t ec_pkey_ctrl

0000000000b19e20 R ec_pkey_meth

00000000008dc700 T engine_pkey_asn1_meths_free

00000000008dce10 T engine_pkey_meths_free

00000000008dc8c0 t engine_unregister_all_pkey_asn1_meths

00000000008dcfd0 t engine_unregister_all_pkey_meths

0000000000962220 T evp_pkey_set_cb_translate

00000000008a9200 t get_optional_pkey_id

00000000008ec1f0 t hmac_pkey_ctrl

0000000000aed360 R hmac_pkey_meth

0000000000e99f40 d openssl_dsa_meth

0000000000e99fa0 d openssl_ecdh_meth

0000000000e99fc0 d openssl_ecdsa_meth

0000000000eaa960 b pkey_asn1_meth_table

00000000008ba990 t pkey_cb

0000000000953b90 t pkey_cmac_cleanup

0000000000953b40 t pkey_cmac_copy

00000000009538f0 t pkey_cmac_ctrl

0000000000953990 t pkey_cmac_ctrl_str

0000000000953b10 t pkey_cmac_init

0000000000953ba0 t pkey_cmac_keygen

000000000095b2f0 t pkey_dh_cleanup

000000000095b370 t pkey_dh_copy

000000000095b020 t pkey_dh_ctrl

000000000095b080 t pkey_dh_ctrl_str

000000000095b120 t pkey_dh_derive

000000000095b310 t pkey_dh_init

000000000095b1a0 t pkey_dh_keygen

000000000095b240 t pkey_dh_paramgen

000000000095b940 t pkey_dsa_cleanup

000000000095b9d0 t pkey_dsa_copy

000000000095b4c0 t pkey_dsa_ctrl

000000000095b400 t pkey_dsa_ctrl_str

000000000095b960 t pkey_dsa_init

000000000095b7d0 t pkey_dsa_keygen

000000000095b870 t pkey_dsa_paramgen

000000000095b740 t pkey_dsa_sign

000000000095b6c0 t pkey_dsa_verify

000000000095ea00 t pkey_ec_cleanup

000000000095ea90 t pkey_ec_copy

000000000095e510 t pkey_ec_ctrl

000000000095e460 t pkey_ec_ctrl_str

000000000095e660 t pkey_ec_derive

000000000095ea40 t pkey_ec_init

000000000095e8b0 t pkey_ec_keygen

000000000095e950 t pkey_ec_paramgen

000000000095e7c0 t pkey_ec_sign

000000000095e740 t pkey_ec_verify

00000000008f84d0 t pkey_get_dsa

00000000008f8400 t pkey_get_eckey

00000000008f85a0 t pkey_get_rsa

00000000008ec610 t pkey_hmac_cleanup

00000000008ec700 t pkey_hmac_copy

00000000008ec340 t pkey_hmac_ctrl

00000000008ec3d0 t pkey_hmac_ctrl_str

00000000008ec670 t pkey_hmac_init

00000000008ec5b0 t pkey_hmac_keygen

0000000000eaa988 b pkey_meth_table

0000000000904ed0 t pkey_rsa_cleanup

0000000000904f20 t pkey_rsa_copy

0000000000904330 t pkey_rsa_ctrl

0000000000904010 t pkey_rsa_ctrl_str

00000000009046f0 t pkey_rsa_decrypt

0000000000904740 t pkey_rsa_encrypt

00000000009049e0 t pkey_rsa_init

0000000000904e00 t pkey_rsa_keygen

0000000000904be0 t pkey_rsa_sign

0000000000904a60 t pkey_rsa_verify

00000000009047e0 t pkey_rsa_verifyrecover

00000000008e9690 t pkey_set_type

0000000000902a70 t rsa_pkey_ctrl

0000000000b04800 R rsa_pkey_meth

00000000008b4220 T ssl_add_clienthello_tlsext

00000000008b3cc0 T ssl_add_serverhello_tlsext

00000000008b29b0 T ssl_check_clienthello_tlsext_early

00000000008b2a70 T ssl_check_clienthello_tlsext_late

00000000008b2770 T ssl_check_serverhello_tlsext

00000000008ac800 T ssl_get_server_send_pkey

00000000008ab300 T ssl_get_sign_pkey

0000000000e99a40 d ssl_mac_pkey_id

00000000008b3260 T ssl_parse_clienthello_tlsext

00000000008b2cc0 T ssl_parse_serverhello_tlsext

00000000008b2b50 T ssl_prepare_clienthello_tlsext

00000000008b2690 T ssl_prepare_serverhello_tlsext

00000000008aee80 t ssl_set_pkey

0000000000e99a30 d ssl_x509_store_ctx_idx.16612

00000000008b1f30 T tls12_get_hash

00000000008b21d0 T tls12_get_req_sig_algs

00000000008b2130 T tls12_get_sigandhash

00000000008b1ef0 T tls12_get_sigid

0000000000e99c00 d tls12_md

0000000000e99bd0 d tls12_sig

0000000000e99c40 d tls12_sigalgs

000000000093e230 t tls1_PRF.clone.0

000000000093d8c0 T tls1_alert_code

00000000008a4c40 T tls1_cbc_remove_padding

000000000093dc20 T tls1_cert_verify_mac

000000000093e7b0 T tls1_change_cipher_state

00000000008b4b80 T tls1_clear

00000000008b1d10 T tls1_default_timeout

00000000008b1d20 T tls1_ec_curve_id2nid

00000000008b1d40 T tls1_ec_nid2curve_id

000000000093dd30 T tls1_enc

000000000093f610 T tls1_export_keying_material

000000000093f330 T tls1_final_finish_mac

00000000008b4ba0 T tls1_free

000000000093f560 T tls1_generate_master_secret

00000000008b1ca0 t tls1_get_client_method

00000000008b4c00 t tls1_get_method

00000000008b50a0 t tls1_get_server_method

000000000093d8e0 T tls1_mac

00000000008a3df0 t tls1_md5_final_raw

00000000008b4bd0 T tls1_new

00000000008b1fb0 T tls1_process_sigalgs

00000000008b24e0 T tls1_process_ticket

000000000093f040 T tls1_setup_key_block

00000000008a3e70 t tls1_sha1_final_raw

00000000008a3f10 t tls1_sha256_final_raw

00000000008a3f50 t tls1_sha512_final_raw

0000000000adeae0 R tls1_version_str

00000000008b2210 t tls_decrypt_ticket

0000000000e9e0c0 d ui_openssl

0000000000b09e00 R v3_pkey_usage_period

00000000008c13d0 t x509_cb

0000000000ea5600 D x509_dir_lookup

0000000000ea5660 D x509_file_lookup

00000000008c0c40 t x509_name_canon

00000000008c11f0 t x509_name_ex_d2i

00000000008c0a10 t x509_name_ex_free

00000000008c1030 t x509_name_ex_i2d

00000000008c0a70 t x509_name_ex_new

00000000008c0950 t x509_name_ex_print

0000000000ae10a0 R x509_name_ff

0000000000914fd0 t x509_object_cmp

0000000000915110 t x509_object_idx_cnt

0000000000921bc0 t x509v3_cache_extensions

So when node is compiled it creates a static object which includes only those functions which it needs. This is a design decision from the core node.js team which allows for minimal bloat.

If you wish to change the behavior of node's linking to OpenSSL from static to shared you can compile node.js from source like so:

$ curl -k http://nodejs.org/dist/v0.10.26/node-v0.10.26.tar.gz | zcat | tar -xf -; cd node-v0.10.26; ./configure --shared-openssl

To answer the second question:

The TLS module uses the certificates specified by you. You can test the functionality of your server and its corresponding certificates using OpenSSL like so:

openssl s_client -connect server:port

That will provide you with details regarding your certificate chain that is not easily available with tools such as curl etc.

The simple fix should be to set this option to false as your testing client is not configured to send any client certificates.

var options = {

/* ... */

rejectUnauthorized: false

/* ... */

}

In regards to the 'actual problem' it stems from a combination of the client certificate store, its trusted CA sources (browser SSL certificate manager) and the server certificate and its CA not being trusted by the client.

Hope that clear it up.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值