{"id":6800,"date":"2016-01-12T19:01:09","date_gmt":"2016-01-12T18:01:09","guid":{"rendered":"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/"},"modified":"2023-06-08T15:03:07","modified_gmt":"2023-06-08T13:03:07","slug":"protect-your-oracle-password-function","status":"publish","type":"post","link":"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/","title":{"rendered":"Protect your oracle password function"},"content":{"rendered":"<p><strong>By Mouhamadou Diaw<\/strong><\/p>\n<p>Every DBA knows the famous oracle password verification script $ORALE_HOME\/rdbms\/admin\/utlpwdmg.sql<br \/>\nThis function can be used to control password complexity.<br \/>\nThis script should be protected from unauthorized users. The reason is that by adding an insert in this function, someone can get passwords of users in the database.<\/p>\n<p>Let\u2019s go through an example<\/p>\n<p>Here is my script (I have modified initial oracle script by just adding the 2 lines after the BEGIN)<\/p>\n<div>\n<div id=\"highlighter_101118\" class=\"syntaxhighlighter  sql\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<div class=\"line number3 index2 alt2\">3<\/div>\n<div class=\"line number4 index3 alt1\">4<\/div>\n<div class=\"line number5 index4 alt2\">5<\/div>\n<div class=\"line number6 index5 alt1\">6<\/div>\n<div class=\"line number7 index6 alt2\">7<\/div>\n<div class=\"line number8 index7 alt1\">8<\/div>\n<div class=\"line number9 index8 alt2\">9<\/div>\n<div class=\"line number10 index9 alt1\">10<\/div>\n<div class=\"line number11 index10 alt2\">11<\/div>\n<div class=\"line number12 index11 alt1\">12<\/div>\n<div class=\"line number13 index12 alt2\">13<\/div>\n<div class=\"line number14 index13 alt1\">14<\/div>\n<div class=\"line number15 index14 alt2\">15<\/div>\n<div class=\"line number16 index15 alt1\">16<\/div>\n<div class=\"line number17 index16 alt2\">17<\/div>\n<div class=\"line number18 index17 alt1\">18<\/div>\n<div class=\"line number19 index18 alt2\">19<\/div>\n<div class=\"line number20 index19 alt1\">20<\/div>\n<div class=\"line number21 index20 alt2\">21<\/div>\n<div class=\"line number22 index21 alt1\">22<\/div>\n<div class=\"line number23 index22 alt2\">23<\/div>\n<div class=\"line number24 index23 alt1\">24<\/div>\n<div class=\"line number25 index24 alt2\">25<\/div>\n<div class=\"line number26 index25 alt1\">26<\/div>\n<div class=\"line number27 index26 alt2\">27<\/div>\n<div class=\"line number28 index27 alt1\">28<\/div>\n<div class=\"line number29 index28 alt2\">29<\/div>\n<div class=\"line number30 index29 alt1\">30<\/div>\n<div class=\"line number31 index30 alt2\">31<\/div>\n<div class=\"line number32 index31 alt1\">32<\/div>\n<div class=\"line number33 index32 alt2\">33<\/div>\n<div class=\"line number34 index33 alt1\">34<\/div>\n<div class=\"line number35 index34 alt2\">35<\/div>\n<div class=\"line number36 index35 alt1\">36<\/div>\n<div class=\"line number37 index36 alt2\">37<\/div>\n<div class=\"line number38 index37 alt1\">38<\/div>\n<div class=\"line number39 index38 alt2\">39<\/div>\n<div class=\"line number40 index39 alt1\">40<\/div>\n<div class=\"line number41 index40 alt2\">41<\/div>\n<div class=\"line number42 index41 alt1\">42<\/div>\n<div class=\"line number43 index42 alt2\">43<\/div>\n<div class=\"line number44 index43 alt1\">44<\/div>\n<div class=\"line number45 index44 alt2\">45<\/div>\n<div class=\"line number46 index45 alt1\">46<\/div>\n<div class=\"line number47 index46 alt2\">47<\/div>\n<div class=\"line number48 index47 alt1\">48<\/div>\n<div class=\"line number49 index48 alt2\">49<\/div>\n<div class=\"line number50 index49 alt1\">50<\/div>\n<div class=\"line number51 index50 alt2\">51<\/div>\n<div class=\"line number52 index51 alt1\">52<\/div>\n<div class=\"line number53 index52 alt2\">53<\/div>\n<div class=\"line number54 index53 alt1\">54<\/div>\n<div class=\"line number55 index54 alt2\">55<\/div>\n<div class=\"line number56 index55 alt1\">56<\/div>\n<div class=\"line number57 index56 alt2\">57<\/div>\n<div class=\"line number58 index57 alt1\">58<\/div>\n<div class=\"line number59 index58 alt2\">59<\/div>\n<div class=\"line number60 index59 alt1\">60<\/div>\n<div class=\"line number61 index60 alt2\">61<\/div>\n<div class=\"line number62 index61 alt1\">62<\/div>\n<div class=\"line number63 index62 alt2\">63<\/div>\n<div class=\"line number64 index63 alt1\">64<\/div>\n<div class=\"line number65 index64 alt2\">65<\/div>\n<div class=\"line number66 index65 alt1\">66<\/div>\n<div class=\"line number67 index66 alt2\">67<\/div>\n<div class=\"line number68 index67 alt1\">68<\/div>\n<div class=\"line number69 index68 alt2\">69<\/div>\n<div class=\"line number70 index69 alt1\">70<\/div>\n<div class=\"line number71 index70 alt2\">71<\/div>\n<div class=\"line number72 index71 alt1\">72<\/div>\n<div class=\"line number73 index72 alt2\">73<\/div>\n<div class=\"line number74 index73 alt1\">74<\/div>\n<div class=\"line number75 index74 alt2\">75<\/div>\n<div class=\"line number76 index75 alt1\">76<\/div>\n<div class=\"line number77 index76 alt2\">77<\/div>\n<div class=\"line number78 index77 alt1\">78<\/div>\n<div class=\"line number79 index78 alt2\">79<\/div>\n<div class=\"line number80 index79 alt1\">80<\/div>\n<div class=\"line number81 index80 alt2\">81<\/div>\n<div class=\"line number82 index81 alt1\">82<\/div>\n<div class=\"line number83 index82 alt2\">83<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"sql keyword\">CREATE<\/code> <code class=\"sql color1\">OR<\/code> <code class=\"sql color2\">REPLACE<\/code> <code class=\"sql keyword\">FUNCTION<\/code> <code class=\"sql plain\">ora12c_verify_function<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"sql plain\">(username varchar2,<\/code><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"sql spaces\">\u00a0<\/code><code class=\"sql keyword\">password<\/code> <code class=\"sql plain\">varchar2,<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><code class=\"sql spaces\">\u00a0<\/code><code class=\"sql plain\">old_password varchar2)<\/code><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"sql keyword\">RETURN<\/code> <code class=\"sql plain\">boolean <\/code><code class=\"sql keyword\">IS<\/code><\/div>\n<div class=\"line number6 index5 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">differ <\/code><code class=\"sql keyword\">integer<\/code><code class=\"sql plain\">;<\/code><\/div>\n<div class=\"line number7 index6 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">pw_lower varchar2(256); <\/code><\/div>\n<div class=\"line number8 index7 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">db_name varchar2(40);<\/code><\/div>\n<div class=\"line number9 index8 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">i <\/code><code class=\"sql keyword\">integer<\/code><code class=\"sql plain\">;<\/code><\/div>\n<div class=\"line number10 index9 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">simple_password varchar2(10);<\/code><\/div>\n<div class=\"line number11 index10 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">reverse_user varchar2(32);<\/code><\/div>\n<div class=\"line number12 index11 alt1\"><code class=\"sql keyword\">BEGIN<\/code><\/div>\n<div class=\"line number13 index12 alt2\"><code class=\"sql comments\">-- ########## #Insert here these lines #################<\/code><\/div>\n<div class=\"line number14 index13 alt1\"><\/div>\n<div class=\"line number15 index14 alt2\"><code class=\"sql keyword\">INSERT<\/code> <code class=\"sql keyword\">INTO<\/code> <code class=\"sql plain\">MYTAB <\/code><code class=\"sql keyword\">VALUES<\/code> <code class=\"sql plain\">(username,<\/code><code class=\"sql keyword\">password<\/code><code class=\"sql plain\">);<\/code><\/div>\n<div class=\"line number16 index15 alt1\"><code class=\"sql keyword\">COMMIT<\/code><code class=\"sql plain\">;<\/code><\/div>\n<div class=\"line number17 index16 alt2\"><\/div>\n<div class=\"line number18 index17 alt1\"><code class=\"sql comments\">--#######################END INSERT ################<\/code><\/div>\n<div class=\"line number19 index18 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">IF <\/code><code class=\"sql color1\">NOT<\/code> <code class=\"sql plain\">ora_complexity_check(<\/code><code class=\"sql keyword\">password<\/code><code class=\"sql plain\">, chars =&gt; 8, letter =&gt; 1, digit =&gt; 1) <\/code><code class=\"sql keyword\">THEN<\/code><\/div>\n<div class=\"line number20 index19 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">RETURN<\/code><code class=\"sql plain\">(<\/code><code class=\"sql keyword\">FALSE<\/code><code class=\"sql plain\">);<\/code><\/div>\n<div class=\"line number21 index20 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">END<\/code> <code class=\"sql plain\">IF;<\/code><\/div>\n<div class=\"line number22 index21 alt1\"><\/div>\n<div class=\"line number23 index22 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql comments\">-- Check if the password contains the username<\/code><\/div>\n<div class=\"line number24 index23 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">pw_lower := NLS_LOWER(<\/code><code class=\"sql keyword\">password<\/code><code class=\"sql plain\">);<\/code><\/div>\n<div class=\"line number25 index24 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">IF instr(pw_lower, NLS_LOWER(username)) &gt; 0 <\/code><code class=\"sql keyword\">THEN<\/code><\/div>\n<div class=\"line number26 index25 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">raise_application_error(-20002, <\/code><code class=\"sql string\">'Password contains the username'<\/code><code class=\"sql plain\">);<\/code><\/div>\n<div class=\"line number27 index26 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">END<\/code> <code class=\"sql plain\">IF;<\/code><\/div>\n<div class=\"line number28 index27 alt1\"><\/div>\n<div class=\"line number29 index28 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql comments\">-- Check if the password contains the username reversed<\/code><\/div>\n<div class=\"line number30 index29 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">reverse_user := <\/code><code class=\"sql string\">''<\/code><code class=\"sql plain\">;<\/code><\/div>\n<div class=\"line number31 index30 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">FOR<\/code> <code class=\"sql plain\">i <\/code><code class=\"sql color1\">in<\/code> <code class=\"sql plain\">REVERSE 1..length(username) LOOP<\/code><\/div>\n<div class=\"line number32 index31 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">reverse_user := reverse_user || substr(username, i, 1);<\/code><\/div>\n<div class=\"line number33 index32 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">END<\/code> <code class=\"sql plain\">LOOP;<\/code><\/div>\n<div class=\"line number34 index33 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">IF instr(pw_lower, NLS_LOWER(reverse_user)) &gt; 0 <\/code><code class=\"sql keyword\">THEN<\/code><\/div>\n<div class=\"line number35 index34 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">raise_application_error(-20003, <\/code><code class=\"sql string\">'Password contains the username '<\/code> <code class=\"sql plain\">|| <\/code><\/div>\n<div class=\"line number36 index35 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql string\">'reversed'<\/code><code class=\"sql plain\">);<\/code><\/div>\n<div class=\"line number37 index36 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">END<\/code> <code class=\"sql plain\">IF;<\/code><\/div>\n<div class=\"line number38 index37 alt1\"><\/div>\n<div class=\"line number39 index38 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql comments\">-- Check if the password contains the server name<\/code><\/div>\n<div class=\"line number40 index39 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">select<\/code> <code class=\"sql keyword\">name<\/code> <code class=\"sql keyword\">into<\/code> <code class=\"sql plain\">db_name <\/code><code class=\"sql keyword\">from<\/code> <code class=\"sql plain\">sys.v$<\/code><code class=\"sql keyword\">database<\/code><code class=\"sql plain\">;<\/code><\/div>\n<div class=\"line number41 index40 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">IF instr(pw_lower, NLS_LOWER(db_name)) &gt; 0 <\/code><code class=\"sql keyword\">THEN<\/code><\/div>\n<div class=\"line number42 index41 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">raise_application_error(-20004, <\/code><code class=\"sql string\">'Password contains the server name'<\/code><code class=\"sql plain\">);<\/code><\/div>\n<div class=\"line number43 index42 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">END<\/code> <code class=\"sql plain\">IF;<\/code><\/div>\n<div class=\"line number44 index43 alt1\"><\/div>\n<div class=\"line number45 index44 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql comments\">-- Check if the password contains 'oracle'<\/code><\/div>\n<div class=\"line number46 index45 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">IF instr(pw_lower, <\/code><code class=\"sql string\">'oracle'<\/code><code class=\"sql plain\">) &gt; 0 <\/code><code class=\"sql keyword\">THEN<\/code><\/div>\n<div class=\"line number47 index46 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">raise_application_error(-20006, <\/code><code class=\"sql string\">'Password too simple'<\/code><code class=\"sql plain\">);<\/code><\/div>\n<div class=\"line number48 index47 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">END<\/code> <code class=\"sql plain\">IF;<\/code><\/div>\n<div class=\"line number49 index48 alt2\"><\/div>\n<div class=\"line number50 index49 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql comments\">-- Check if the password is too simple. A dictionary of words may be<\/code><\/div>\n<div class=\"line number51 index50 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql comments\">-- maintained and a check may be made so as not to allow the words<\/code><\/div>\n<div class=\"line number52 index51 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql comments\">-- that are too simple for the password.<\/code><\/div>\n<div class=\"line number53 index52 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">IF pw_lower <\/code><code class=\"sql color1\">IN<\/code> <code class=\"sql plain\">(<\/code><code class=\"sql string\">'welcome1'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'database1'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'account1'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'user1234'<\/code><code class=\"sql plain\">,<\/code><\/div>\n<div class=\"line number54 index53 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql string\">'password1'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'oracle123'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'computer1'<\/code><code class=\"sql plain\">, <\/code><\/div>\n<div class=\"line number55 index54 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql string\">'abcdefg1'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'change_on_install'<\/code><code class=\"sql plain\">) <\/code><code class=\"sql keyword\">THEN<\/code><\/div>\n<div class=\"line number56 index55 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">raise_application_error(-20006, <\/code><code class=\"sql string\">'Password too simple'<\/code><code class=\"sql plain\">);<\/code><\/div>\n<div class=\"line number57 index56 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">END<\/code> <code class=\"sql plain\">IF;<\/code><\/div>\n<div class=\"line number58 index57 alt1\"><\/div>\n<div class=\"line number59 index58 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql comments\">-- Check if the password differs from the previous password by at least<\/code><\/div>\n<div class=\"line number60 index59 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql comments\">-- 3 characters<\/code><\/div>\n<div class=\"line number61 index60 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">IF old_password <\/code><code class=\"sql keyword\">IS<\/code> <code class=\"sql color1\">NOT<\/code> <code class=\"sql color1\">NULL<\/code> <code class=\"sql keyword\">THEN<\/code><\/div>\n<div class=\"line number62 index61 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">differ := ora_string_distance(old_password, <\/code><code class=\"sql keyword\">password<\/code><code class=\"sql plain\">);<\/code><\/div>\n<div class=\"line number63 index62 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">IF differ &lt; 3 <\/code><code class=\"sql keyword\">THEN<\/code><\/div>\n<div class=\"line number64 index63 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">raise_application_error(-20010, <\/code><code class=\"sql string\">'Password should differ from the '<\/code><\/div>\n<div class=\"line number65 index64 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">|| <\/code><code class=\"sql string\">'old password by at least 3 characters'<\/code><code class=\"sql plain\">);<\/code><\/div>\n<div class=\"line number66 index65 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">END<\/code> <code class=\"sql plain\">IF;<\/code><\/div>\n<div class=\"line number67 index66 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">END<\/code> <code class=\"sql plain\">IF ;<\/code><\/div>\n<div class=\"line number68 index67 alt1\"><\/div>\n<div class=\"line number69 index68 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">RETURN<\/code><code class=\"sql plain\">(<\/code><code class=\"sql keyword\">TRUE<\/code><code class=\"sql plain\">);<\/code><\/div>\n<div class=\"line number70 index69 alt1\"><code class=\"sql keyword\">END<\/code><code class=\"sql plain\">;<\/code><\/div>\n<div class=\"line number71 index70 alt2\"><code class=\"sql plain\">\/<\/code><\/div>\n<div class=\"line number72 index71 alt1\"><\/div>\n<div class=\"line number73 index72 alt2\"><code class=\"sql keyword\">GRANT<\/code> <code class=\"sql keyword\">EXECUTE<\/code> <code class=\"sql keyword\">ON<\/code> <code class=\"sql plain\">ora12c_verify_function <\/code><code class=\"sql keyword\">TO<\/code> <code class=\"sql keyword\">PUBLIC<\/code><code class=\"sql plain\">;<\/code><\/div>\n<div class=\"line number74 index73 alt1\"><\/div>\n<div class=\"line number75 index74 alt2\"><\/div>\n<div class=\"line number76 index75 alt1\"><code class=\"sql keyword\">ALTER<\/code> <code class=\"sql plain\">PROFILE profile1\u00a0 LIMIT<\/code><\/div>\n<div class=\"line number77 index76 alt2\"><code class=\"sql plain\">PASSWORD_LIFE_TIME 180<\/code><\/div>\n<div class=\"line number78 index77 alt1\"><code class=\"sql plain\">PASSWORD_GRACE_TIME 7<\/code><\/div>\n<div class=\"line number79 index78 alt2\"><code class=\"sql plain\">PASSWORD_REUSE_TIME UNLIMITED<\/code><\/div>\n<div class=\"line number80 index79 alt1\"><code class=\"sql plain\">PASSWORD_REUSE_MAX\u00a0 UNLIMITED<\/code><\/div>\n<div class=\"line number81 index80 alt2\"><code class=\"sql plain\">FAILED_LOGIN_ATTEMPTS 10<\/code><\/div>\n<div class=\"line number82 index81 alt1\"><code class=\"sql plain\">PASSWORD_LOCK_TIME 1<\/code><\/div>\n<div class=\"line number83 index82 alt2\"><code class=\"sql plain\">PASSWORD_VERIFY_FUNCTION ora12c_verify_function;<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>Now let\u2019s create the profile1 and the table mytab, and after let\u2019s execute the script<\/p>\n<div>\n<div id=\"highlighter_597273\" class=\"syntaxhighlighter  sql\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<div class=\"line number3 index2 alt2\">3<\/div>\n<div class=\"line number4 index3 alt1\">4<\/div>\n<div class=\"line number5 index4 alt2\">5<\/div>\n<div class=\"line number6 index5 alt1\">6<\/div>\n<div class=\"line number7 index6 alt2\">7<\/div>\n<div class=\"line number8 index7 alt1\">8<\/div>\n<div class=\"line number9 index8 alt2\">9<\/div>\n<div class=\"line number10 index9 alt1\">10<\/div>\n<div class=\"line number11 index10 alt2\">11<\/div>\n<div class=\"line number12 index11 alt1\">12<\/div>\n<div class=\"line number13 index12 alt2\">13<\/div>\n<div class=\"line number14 index13 alt1\">14<\/div>\n<div class=\"line number15 index14 alt2\">15<\/div>\n<div class=\"line number16 index15 alt1\">16<\/div>\n<div class=\"line number17 index16 alt2\">17<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"sql spaces\">\u00a0<\/code><code class=\"sql plain\">SQL&gt; <\/code><code class=\"sql keyword\">create<\/code> <code class=\"sql plain\">profile profile1 limit connect_time 45;<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"sql plain\">Profile created.<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"sql plain\">SQL&gt; <\/code><code class=\"sql keyword\">create<\/code> <code class=\"sql keyword\">table<\/code> <code class=\"sql plain\">mytab (login varchar2(30),passe varchar2(30));<\/code><\/div>\n<div class=\"line number6 index5 alt1\"><\/div>\n<div class=\"line number7 index6 alt2\"><code class=\"sql keyword\">Table<\/code> <code class=\"sql plain\">created.<\/code><\/div>\n<div class=\"line number8 index7 alt1\"><\/div>\n<div class=\"line number9 index8 alt2\"><code class=\"sql plain\">SQL&gt; @?\/rdbms\/admin\/utlpwdmg_mod.sql<\/code><\/div>\n<div class=\"line number10 index9 alt1\"><\/div>\n<div class=\"line number11 index10 alt2\"><code class=\"sql keyword\">Function<\/code> <code class=\"sql plain\">created.<\/code><\/div>\n<div class=\"line number12 index11 alt1\"><\/div>\n<div class=\"line number13 index12 alt2\"><code class=\"sql keyword\">Grant<\/code> <code class=\"sql plain\">succeeded.<\/code><\/div>\n<div class=\"line number14 index13 alt1\"><\/div>\n<div class=\"line number15 index14 alt2\"><code class=\"sql plain\">Profile altered.<\/code><\/div>\n<div class=\"line number16 index15 alt1\"><\/div>\n<div class=\"line number17 index16 alt2\"><code class=\"sql plain\">SQL&gt;<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>At this moment our password complexity is now working<\/p>\n<div>\n<div id=\"highlighter_330089\" class=\"syntaxhighlighter  sql\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<div class=\"line number3 index2 alt2\">3<\/div>\n<div class=\"line number4 index3 alt1\">4<\/div>\n<div class=\"line number5 index4 alt2\">5<\/div>\n<div class=\"line number6 index5 alt1\">6<\/div>\n<div class=\"line number7 index6 alt2\">7<\/div>\n<div class=\"line number8 index7 alt1\">8<\/div>\n<div class=\"line number9 index8 alt2\">9<\/div>\n<div class=\"line number10 index9 alt1\">10<\/div>\n<div class=\"line number11 index10 alt2\">11<\/div>\n<div class=\"line number12 index11 alt1\">12<\/div>\n<div class=\"line number13 index12 alt2\">13<\/div>\n<div class=\"line number14 index13 alt1\">14<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"sql plain\">SQL&gt; <\/code><code class=\"sql keyword\">create<\/code> <code class=\"sql color2\">user<\/code> <code class=\"sql plain\">joe identified <\/code><code class=\"sql keyword\">by<\/code> <code class=\"sql plain\">joe profile profile1;<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"sql keyword\">create<\/code> <code class=\"sql color2\">user<\/code> <code class=\"sql plain\">joe identified <\/code><code class=\"sql keyword\">by<\/code> <code class=\"sql plain\">joe profile profile1<\/code><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"sql plain\">*<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><code class=\"sql plain\">ERROR <\/code><code class=\"sql keyword\">at<\/code> <code class=\"sql plain\">line 1:<\/code><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"sql plain\">ORA-28003: <\/code><code class=\"sql keyword\">password<\/code> <code class=\"sql plain\">verification <\/code><code class=\"sql keyword\">for<\/code> <code class=\"sql plain\">the specified <\/code><code class=\"sql keyword\">password<\/code> <code class=\"sql plain\">failed<\/code><\/div>\n<div class=\"line number6 index5 alt1\"><code class=\"sql plain\">ORA-20001: <\/code><code class=\"sql keyword\">Password<\/code> <code class=\"sql plain\">length less than 8<\/code><\/div>\n<div class=\"line number7 index6 alt2\"><\/div>\n<div class=\"line number8 index7 alt1\"><code class=\"sql plain\">SQL&gt; <\/code><code class=\"sql keyword\">create<\/code> <code class=\"sql color2\">user<\/code> <code class=\"sql plain\">joe identified <\/code><code class=\"sql keyword\">by<\/code> <code class=\"sql string\">\"DarV@rd0r25\"<\/code> <code class=\"sql plain\">profile profile1;<\/code><\/div>\n<div class=\"line number9 index8 alt2\"><\/div>\n<div class=\"line number10 index9 alt1\"><code class=\"sql color2\">User<\/code> <code class=\"sql plain\">created.<\/code><\/div>\n<div class=\"line number11 index10 alt2\"><\/div>\n<div class=\"line number12 index11 alt1\"><code class=\"sql plain\">SQL&gt; <\/code><code class=\"sql keyword\">alter<\/code> <code class=\"sql color2\">user<\/code> <code class=\"sql plain\">joe identified <\/code><code class=\"sql keyword\">by<\/code> <code class=\"sql string\">\"Leil@Pri120\"<\/code><code class=\"sql plain\">;<\/code><\/div>\n<div class=\"line number13 index12 alt2\"><\/div>\n<div class=\"line number14 index13 alt1\"><code class=\"sql color2\">User<\/code> <code class=\"sql plain\">altered.<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>But now let\u2019s do a select in\u00a0\u00a0our mytab table<\/p>\n<div>\n<div id=\"highlighter_980201\" class=\"syntaxhighlighter  sql\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<div class=\"line number3 index2 alt2\">3<\/div>\n<div class=\"line number4 index3 alt1\">4<\/div>\n<div class=\"line number5 index4 alt2\">5<\/div>\n<div class=\"line number6 index5 alt1\">6<\/div>\n<div class=\"line number7 index6 alt2\">7<\/div>\n<div class=\"line number8 index7 alt1\">8<\/div>\n<div class=\"line number9 index8 alt2\">9<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"sql plain\">SQL&gt; <\/code><code class=\"sql keyword\">select<\/code> <code class=\"sql plain\">* <\/code><code class=\"sql keyword\">from<\/code> <code class=\"sql plain\">mytab;<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"sql plain\">LOGIN\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 PASSE<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><code class=\"sql comments\">------------------------------ ------------------------------<\/code><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"sql plain\">JOE\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 joe<\/code><\/div>\n<div class=\"line number6 index5 alt1\"><code class=\"sql plain\">JOE\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 DarV@rd0r25<\/code><\/div>\n<div class=\"line number7 index6 alt2\"><code class=\"sql plain\">JOE\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 Leil@Pri120<\/code><\/div>\n<div class=\"line number8 index7 alt1\"><\/div>\n<div class=\"line number9 index8 alt2\"><code class=\"sql plain\">SQL&gt;<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>Waw we have passwords, and even if we alter the password user, we will have the new one in the table.<\/p>\n<p>That means that we have to protect our password verification script and we have to regularly audit the script to see if there is any change inside.<\/p>\n<p>This is not a flaw , but just we must be careful when using this function.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>By Mouhamadou Diaw Every DBA knows the famous oracle password verification script $ORALE_HOME\/rdbms\/admin\/utlpwdmg.sql This function can be used to control password complexity. This script should be protected from unauthorized users. The reason is that by adding an insert in this function, someone can get passwords of users in the database. Let\u2019s go through an example [&hellip;]<\/p>\n","protected":false},"author":27,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[229],"tags":[],"type_dbi":[],"class_list":["post-6800","post","type-post","status-publish","format-standard","hentry","category-database-administration-monitoring"],"acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v27.2 (Yoast SEO v27.2) - https:\/\/yoast.com\/product\/yoast-seo-premium-wordpress\/ -->\n<title>Protect your oracle password function - dbi Blog<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Protect your oracle password function\" \/>\n<meta property=\"og:description\" content=\"By Mouhamadou Diaw Every DBA knows the famous oracle password verification script $ORALE_HOME\/rdbms\/admin\/utlpwdmg.sql This function can be used to control password complexity. This script should be protected from unauthorized users. The reason is that by adding an insert in this function, someone can get passwords of users in the database. Let\u2019s go through an example [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/\" \/>\n<meta property=\"og:site_name\" content=\"dbi Blog\" \/>\n<meta property=\"article:published_time\" content=\"2016-01-12T18:01:09+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2023-06-08T13:03:07+00:00\" \/>\n<meta name=\"author\" content=\"Oracle Team\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Oracle Team\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"4 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/\"},\"author\":{\"name\":\"Oracle Team\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/66ab87129f2d357f09971bc7936a77ee\"},\"headline\":\"Protect your oracle password function\",\"datePublished\":\"2016-01-12T18:01:09+00:00\",\"dateModified\":\"2023-06-08T13:03:07+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/\"},\"wordCount\":184,\"commentCount\":1,\"articleSection\":[\"Database Administration &amp; Monitoring\"],\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/\",\"url\":\"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/\",\"name\":\"Protect your oracle password function - dbi Blog\",\"isPartOf\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#website\"},\"datePublished\":\"2016-01-12T18:01:09+00:00\",\"dateModified\":\"2023-06-08T13:03:07+00:00\",\"author\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/66ab87129f2d357f09971bc7936a77ee\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Accueil\",\"item\":\"https:\/\/www.dbi-services.com\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Protect your oracle password function\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#website\",\"url\":\"https:\/\/www.dbi-services.com\/blog\/\",\"name\":\"dbi Blog\",\"description\":\"\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/www.dbi-services.com\/blog\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"en-US\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/66ab87129f2d357f09971bc7936a77ee\",\"name\":\"Oracle Team\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/secure.gravatar.com\/avatar\/f711f7cd2c9b09bf2627133755b569fb5be0694810cfd33033bdd095fedba86d?s=96&d=mm&r=g\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/f711f7cd2c9b09bf2627133755b569fb5be0694810cfd33033bdd095fedba86d?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/f711f7cd2c9b09bf2627133755b569fb5be0694810cfd33033bdd095fedba86d?s=96&d=mm&r=g\",\"caption\":\"Oracle Team\"},\"url\":\"https:\/\/www.dbi-services.com\/blog\/author\/oracle-team\/\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"Protect your oracle password function - dbi Blog","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/","og_locale":"en_US","og_type":"article","og_title":"Protect your oracle password function","og_description":"By Mouhamadou Diaw Every DBA knows the famous oracle password verification script $ORALE_HOME\/rdbms\/admin\/utlpwdmg.sql This function can be used to control password complexity. This script should be protected from unauthorized users. The reason is that by adding an insert in this function, someone can get passwords of users in the database. Let\u2019s go through an example [&hellip;]","og_url":"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/","og_site_name":"dbi Blog","article_published_time":"2016-01-12T18:01:09+00:00","article_modified_time":"2023-06-08T13:03:07+00:00","author":"Oracle Team","twitter_card":"summary_large_image","twitter_misc":{"Written by":"Oracle Team","Est. reading time":"4 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/#article","isPartOf":{"@id":"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/"},"author":{"name":"Oracle Team","@id":"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/66ab87129f2d357f09971bc7936a77ee"},"headline":"Protect your oracle password function","datePublished":"2016-01-12T18:01:09+00:00","dateModified":"2023-06-08T13:03:07+00:00","mainEntityOfPage":{"@id":"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/"},"wordCount":184,"commentCount":1,"articleSection":["Database Administration &amp; Monitoring"],"inLanguage":"en-US","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/","url":"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/","name":"Protect your oracle password function - dbi Blog","isPartOf":{"@id":"https:\/\/www.dbi-services.com\/blog\/#website"},"datePublished":"2016-01-12T18:01:09+00:00","dateModified":"2023-06-08T13:03:07+00:00","author":{"@id":"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/66ab87129f2d357f09971bc7936a77ee"},"breadcrumb":{"@id":"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.dbi-services.com\/blog\/protect-your-oracle-password-function\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Accueil","item":"https:\/\/www.dbi-services.com\/blog\/"},{"@type":"ListItem","position":2,"name":"Protect your oracle password function"}]},{"@type":"WebSite","@id":"https:\/\/www.dbi-services.com\/blog\/#website","url":"https:\/\/www.dbi-services.com\/blog\/","name":"dbi Blog","description":"","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.dbi-services.com\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Person","@id":"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/66ab87129f2d357f09971bc7936a77ee","name":"Oracle Team","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/secure.gravatar.com\/avatar\/f711f7cd2c9b09bf2627133755b569fb5be0694810cfd33033bdd095fedba86d?s=96&d=mm&r=g","url":"https:\/\/secure.gravatar.com\/avatar\/f711f7cd2c9b09bf2627133755b569fb5be0694810cfd33033bdd095fedba86d?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/f711f7cd2c9b09bf2627133755b569fb5be0694810cfd33033bdd095fedba86d?s=96&d=mm&r=g","caption":"Oracle Team"},"url":"https:\/\/www.dbi-services.com\/blog\/author\/oracle-team\/"}]}},"_links":{"self":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/posts\/6800","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/users\/27"}],"replies":[{"embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/comments?post=6800"}],"version-history":[{"count":1,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/posts\/6800\/revisions"}],"predecessor-version":[{"id":25669,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/posts\/6800\/revisions\/25669"}],"wp:attachment":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/media?parent=6800"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/categories?post=6800"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/tags?post=6800"},{"taxonomy":"type","embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/type_dbi?post=6800"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}