الانتقال إلى المحتوى
View in the app

A better way to browse. Learn more.

مجموعة مستخدمي أوراكل العربية

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

مشكلتي ف عرض الصورة اللي مخزنة ف ال Db

Featured Replies

بتاريخ:

انا عندي كود اللي يخزن الصورة ف DB شغال والصورة لاقيها ف الDB لكن المشكة ف عرص الصورة من الDB بواسطة الservlet .. بيطلعلي ال erorr دا 

 

 

<Oct 10, 2017 10:39:43,450 AM AST> <Error> <HTTP> <BEA-101017> <[servletContext@196074337[app:Application7 module:Application7-ViewController-context-root path:null spec-version:3.1], request: weblogic.servlet.internal.ServletRequestImpl@25b8fc6f[
GET /Application7-ViewController-context-root/showimage?pName=mohamed HTTP/1.1
Connection: keep-alive
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/61.0.3163.100 Safari/537.36
Accept: image/webp,image/apng,image/*,*/*;q=0.8
DNT: 1
Accept-Encoding: gzip, deflate, br
Accept-Language: en-US,en;q=0.8
 
]] Root cause of ServletException.
java.lang.NullPointerException
at view.ShowImage.doGet(ShowImage.java:72)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:687)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:790)
at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:286)
at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:260)
Truncated. see log file for complete stacktrace
 
ودا كود الservlet بتاعي 
 
package view;
 
import java.io.BufferedInputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.io.PrintWriter;
 
import java.sql.Blob;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
 
import javax.naming.Context;
 
import javax.naming.InitialContext;
 
 
import javax.naming.NamingException;
 
import javax.servlet.*;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.*;
 
import javax.sql.DataSource;
 
 
 
 
@WebServlet(name = "ShowImage", urlPatterns = { "/showimage" })
public class ShowImage extends HttpServlet {
    private static final String CONTENT_TYPE = "image/png";
 
    public void init(ServletConfig config) throws ServletException {
        super.init(config);
    }
 
    public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        response.setContentType(CONTENT_TYPE);
        OutputStream out = response.getOutputStream();
        String personName = request.getParameter("pName");
        Context conx = null;
        try {
            conx = new InitialContext();
        } catch (NamingException e) {
        }
        DataSource ds = null;
        try {
            ds = (DataSource) conx.lookup("java:comp/env/jdbc/MohConnection1DS");
        } catch (NamingException e) {
        }
        Connection conn= null;
        try {
            conn = ds.getConnection();
        } catch (SQLException e) {
        }
        String sql = "select CARD_IMAGE from TABLE1 where PERSON_NAME = ?";
            
 
 
        PreparedStatement st = null ;
         
 
        ResultSet rs = null ;
        
 
        try {
            st.setString(1,personName);
            st = conn.prepareStatement(sql);
            rs = st.executeQuery();
            while (rs.next()){
             Blob blob;
                blob = (Blob) rs.getBlob("Card_Image");
               BufferedInputStream input = new BufferedInputStream(blob.getBinaryStream());
                byte[] buffer = new byte[10240];
                int imageReade ;
                while ((imageReade = input.read(buffer, 0, 10240))!= -1) {
                    out.write(buffer, 0, imageReade);
                    }
                
                
                }
          
        
            
        } catch (SQLException e) {
        }
        
        }}
 
  • الردود 49
  • المشاهدات 3k
  • البداية
  • اخر رد

أكثر المشاركين في هذا الموضوع

Most Popular Posts

  • ميسم الكرام
    ميسم الكرام

    أما المشكلة الثانية فيما يتعلق برسالة الخطأ   مشلكة ف  Database connection بيقولي    Test failed: Listener refused the connection with the following error: ORA-12505, TNS:listener does not curren

  • ميسم الكرام
    ميسم الكرام

    الأخت :eng_farieda لقد أشرت لي بطلبك بحل مشكلة لهذه المشاركة والمشاركة تضم مشكلتين ، لم أجد حل لهما عند إطلاعي على الردود ولم تشيري لي أي منهما تريدن لها الحل لذلك سأجيب بالحل لكلا المشكلتين   فيما

  • ميسم الكرام
    ميسم الكرام

    بهكذا رسائل الخطأ ننظر إلى نص الرسالة وإلى رقم الرسالة حتى نصل إلى مسبب المشكلة ومنها إلى الحل الصحيح في إدناه رابط إلى أرقام رسائل الخطا وكيف يوضح السبب والسبيل المتبع للحل  http://www.oracle.com/pl

الصور المنشورة

بتاريخ:

 

انا عندي كود اللي يخزن الصورة ف DB شغال والصورة لاقيها ف الDB لكن المشكة ف عرص الصورة من الDB بواسطة الservlet .. بيطلعلي ال erorr دا 

 

 

<Oct 10, 2017 10:39:43,450 AM AST> <Error> <HTTP> <BEA-101017> <[servletContext@196074337[app:Application7 module:Application7-ViewController-context-root path:null spec-version:3.1], request: weblogic.servlet.internal.ServletRequestImpl@25b8fc6f[
GET /Application7-ViewController-context-root/showimage?pName=mohamed HTTP/1.1
Connection: keep-alive
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/61.0.3163.100 Safari/537.36
Accept: image/webp,image/apng,image/*,*/*;q=0.8
DNT: 1
Accept-Encoding: gzip, deflate, br
Accept-Language: en-US,en;q=0.8
 
]] Root cause of ServletException.
java.lang.NullPointerException
at view.ShowImage.doGet(ShowImage.java:72)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:687)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:790)
at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:286)
at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:260)
Truncated. see log file for complete stacktrace
 
ودا كود الservlet بتاعي 

 

package view;
 
import java.io.BufferedInputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.io.PrintWriter;
 
import java.sql.Blob;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
 
import javax.naming.Context;
 
import javax.naming.InitialContext;
 
 
import javax.naming.NamingException;
 
import javax.servlet.*;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.*;
 
import javax.sql.DataSource;
 
 
 
 
@WebServlet(name = "ShowImage", urlPatterns = { "/showimage" })
public class ShowImage extends HttpServlet {
    private static final String CONTENT_TYPE = "image/png";
 
    public void init(ServletConfig config) throws ServletException {
        super.init(config);
    }
 
    public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        response.setContentType(CONTENT_TYPE);
        OutputStream out = response.getOutputStream();
        String personName = request.getParameter("pName");
        Context conx = null;
        try {
            conx = new InitialContext();
        } catch (NamingException e) {
        }
        DataSource ds = null;
        try {
            ds = (DataSource) conx.lookup("java:comp/env/jdbc/MohConnection1DS");
        } catch (NamingException e) {
        }
        Connection conn= null;
        try {
            conn = ds.getConnection();
        } catch (SQLException e) {
        }
        String sql = "select CARD_IMAGE from TABLE1 where PERSON_NAME = ?";
            
 
 
        PreparedStatement st = null ;
         
 
        ResultSet rs = null ;
        
 
        try {
            st.setString(1,personName);
            st = conn.prepareStatement(sql);
            rs = st.executeQuery();
            while (rs.next()){
             Blob blob;
                blob = (Blob) rs.getBlob("Card_Image");
               BufferedInputStream input = new BufferedInputStream(blob.getBinaryStream());
                byte[] buffer = new byte[10240];
                int imageReade ;
                while ((imageReade = input.read(buffer, 0, 10240))!= -1) {
                    out.write(buffer, 0, imageReade);
                    }
                
                
                }
          
        
            
        } catch (SQLException e) {
        }
        
        }}

 

وضح الكود اللي انت كتبه في ال image source

بتاريخ:
  • كاتب الموضوع

دا كود servlet ]

post-170668-0-65404500-1507626622_thumb.png

بتاريخ:

انا ملاحظ ان اسم ال column في جملة ال select مختلف عن ال blob حاول تخليهم زي ما هما في الداتا بيز بالضبط

بتاريخ:
  • كاتب الموضوع

عدلتها ونفس المشكلة برضو 

بتاريخ:

حضرتك شغال علي اصدار كام

بتاريخ:
  • كاتب الموضوع

jdevolper 12C 3.1 

بتاريخ:

طيب بص ونت بتعمل السيرفلت في الاول لاحظ بيبقي فيه خيارين configuration file (web.xml) و annotations خلي الخيار علي الاولي ممكن يكون الخطا هنا اما بالنسبه لكودك فهو صحيح

بتاريخ:
  • كاتب الموضوع

نفس المشكلة 

بتاريخ:
  • كاتب الموضوع

مديني warning موش عارف دا ليه علاقة ولا لا 

post-170668-0-92294100-1507631308_thumb.png

بتاريخ:

لأ ال warrning ده عادي

بتاريخ:

أي سطر يمثل رقم 72؟

بتاريخ:
  • كاتب الموضوع

سطر 72  

 ;("blob = (Blob) rs.getBlob("CARD_IMAGE

بتاريخ:

هل نوع البيانات blob في قاعدة البيانات؟

بتاريخ:
  • كاتب الموضوع

ايوة يا بشمهندس نوعها BLOB 

بتاريخ:

وهل فيها قيمة؟

بتاريخ:
  • كاتب الموضوع

نعم يوجد بها قيمة (BLOB)

بتاريخ:

تأكد أنها ليست null

بتاريخ:
  • كاتب الموضوع

ليست null مكتوب العمود الخاص بالصورة بجانب الاسم (BLOB) وليست (NULL)

بتاريخ:

حسناً اطبع القيمة وتأكد أنها ليست null

بتاريخ:
  • كاتب الموضوع

ف مشكلة انا عامل جملة تطبعلي المتغير اللي ببعتو ل servlet والجملة بتطبع 

لكن الجملة اللي بطبع فيها المخزن ف ال قاعدة البيانات مابتطبعش اصلا 

بتاريخ:

كما ذكرت لك سابقاً اطبع القيمة وتأكد أنها ليست null

بتاريخ:
  • كاتب الموضوع

انا عملت جملة تطبع القيمة بس الجملة مابتتنفذش 

بتاريخ:

حسناً قم بإضافة جملة طباعة بعد كل خطوة لتعرف الخطوة التي توقف التنفيذ عندها

بتاريخ:
  • كاتب الموضوع

انا لما ثبت جملة ال الاستعلام اشتغلت... لكن لما اخلي جملة الاستعلام معتمدة على المتغير اللي بمررو الى السيرفلت بيديني null exception

ممكن حضرتك تبص على الكود المرفق في الصورة ممكن يكون ف حاجة 

 

post-170668-0-61776000-1508137178_thumb.png

انضم إلى المناقشة

يمكنك المشاركة الآن والتسجيل لاحقاً. إذا كان لديك حساب, سجل دخولك الآن لتقوم بالمشاركة من خلال حسابك.

زائر
أضف رد على هذا الموضوع...

برجاء الإنتباه

بإستخدامك للموقع فأنت تتعهد بالموافقة على هذه البنود: سياسة الخصوصية

Account

Navigation

البحث

إعداد إشعارات المتصفح الفورية

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.